Skip to content

Commit

Permalink
fix: popover arrow misaligned when class is prefixed (react-bootstrap…
Browse files Browse the repository at this point in the history
  • Loading branch information
juangl authored Sep 8, 2020
1 parent 3998fd8 commit a0f404a
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 12 deletions.
34 changes: 22 additions & 12 deletions src/usePopperMarginModifiers.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import { useCallback, useMemo, useRef } from 'react';
import hasClass from 'dom-helpers/hasClass';
import { useBootstrapPrefix } from './ThemeProvider';

interface Margins {
top: number;
Expand All @@ -25,17 +26,26 @@ export default function usePopperMarginModifiers(): [
const overlayRef = useRef<HTMLDivElement | null>(null);
const margins = useRef<Margins | null>(null);

const callback = useCallback((overlay: HTMLDivElement) => {
if (
!overlay ||
!(hasClass(overlay, 'popover') || hasClass(overlay, 'dropdown-menu'))
)
return;
const popoverClass = useBootstrapPrefix(undefined, 'popover');
const dropdownMenuClass = useBootstrapPrefix(undefined, 'dropdown-menu');

margins.current = getMargins(overlay);
overlay.style.margin = '0';
overlayRef.current = overlay;
}, []);
const callback = useCallback(
(overlay: HTMLDivElement) => {
if (
!overlay ||
!(
hasClass(overlay, popoverClass) ||
hasClass(overlay, dropdownMenuClass)
)
)
return;

margins.current = getMargins(overlay);
overlay.style.margin = '0';
overlayRef.current = overlay;
},
[popoverClass, dropdownMenuClass],
);

const offset = useMemo(() => {
return {
Expand Down Expand Up @@ -73,7 +83,7 @@ export default function usePopperMarginModifiers(): [
if (
!overlayRef.current ||
!state.elements.arrow ||
!hasClass(overlayRef.current, 'popover') ||
!hasClass(overlayRef.current, popoverClass) ||
!state.modifiersData['arrow#persistent']
) {
return undefined;
Expand All @@ -94,7 +104,7 @@ export default function usePopperMarginModifiers(): [
};
},
};
}, []);
}, [popoverClass]);

return [callback, [offset, popoverArrowMargins]];
}
21 changes: 21 additions & 0 deletions test/usePopperMarginModifiersSpec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import React from 'react';
import { mount } from 'enzyme';

import ThemeProvider from '../src/ThemeProvider';
import Overlay from '../src/Overlay';
import Popover from '../src/Popover';

describe('usePopperMarginModifiers', () => {
it('Should set arrow margin to 0px with prefixed popover and dropdown-menu', () => {
const wrapper = mount(
<ThemeProvider prefixes={{ popover: 'prefixed' }}>
<Overlay show>
<Popover id="test-popover" />
</Overlay>
</ThemeProvider>,
);

const margin = wrapper.find('.arrow').getDOMNode().style.margin;
assert.equal(margin, '0px');
});
});

0 comments on commit a0f404a

Please sign in to comment.