Skip to content

Commit

Permalink
fix: undo the clear observers (#523)
Browse files Browse the repository at this point in the history
  • Loading branch information
thebuilder authored Nov 25, 2021
1 parent 6ed16e2 commit 249de1a
Show file tree
Hide file tree
Showing 3 changed files with 5 additions and 7 deletions.
2 changes: 1 addition & 1 deletion src/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import * as React from 'react';
import { InView } from './InView';
export { InView } from './InView';
export { useInView } from './useInView';
export { observe, _observerMap } from './observe';
export { observe } from './observe';

export default InView;

Expand Down
8 changes: 4 additions & 4 deletions src/observe.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { ObserverInstanceCallback } from './index';

export const _observerMap = new Map<
const observerMap = new Map<
string,
{
id: string;
Expand Down Expand Up @@ -44,7 +44,7 @@ export function optionsToId(options: IntersectionObserverInit) {
function createObserver(options: IntersectionObserverInit) {
// Create a unique ID for this observer instance, based on the root, root margin and threshold.
let id = optionsToId(options);
let instance = _observerMap.get(id);
let instance = observerMap.get(id);

if (!instance) {
// Create a map of elements this observer is going to observe. Each element has a list of callbacks that should be triggered, once it comes into view.
Expand Down Expand Up @@ -85,7 +85,7 @@ function createObserver(options: IntersectionObserverInit) {
elements,
};

_observerMap.set(id, instance);
observerMap.set(id, instance);
}

return instance;
Expand Down Expand Up @@ -128,7 +128,7 @@ export function observe(
if (elements.size === 0) {
// No more elements are being observer by this instance, so destroy it
observer.disconnect();
_observerMap.delete(id);
observerMap.delete(id);
}
};
}
2 changes: 0 additions & 2 deletions src/test-utils.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import { act } from 'react-dom/test-utils';
import { _observerMap } from './index';

type Item = {
callback: IntersectionObserverCallback;
Expand Down Expand Up @@ -49,7 +48,6 @@ afterEach(() => {
// @ts-ignore
global.IntersectionObserver.mockClear();
observers.clear();
_observerMap.clear();
});

function triggerIntersection(
Expand Down

1 comment on commit 249de1a

@vercel
Copy link

@vercel vercel bot commented on 249de1a Nov 25, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.