Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add lazyRoot optional property to next/image component #33290

Merged
merged 25 commits into from
Jan 25, 2022
Merged
Show file tree
Hide file tree
Changes from 10 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
132fdbb
Added 'rootEl' oprional property to next/Image component resembling '…
11koukou Jan 13, 2022
3fd478a
Merge branch 'canary' into koukou
11koukou Jan 13, 2022
b7c1af6
Merge branch 'canary' into koukou
11koukou Jan 14, 2022
6a59d95
Merge branch 'canary' into koukou
11koukou Jan 14, 2022
36fb8c6
Merge branch 'canary' into koukou
11koukou Jan 14, 2022
4a7922d
Merge branch 'canary' into koukou
11koukou Jan 14, 2022
3e8f06a
Merge branch 'canary' into koukou
11koukou Jan 15, 2022
12062ac
changed 'rootEl' to 'lazyBoundary' and its type as well
11koukou Jan 15, 2022
b25f147
Merge branch 'canary' of https://github.com/vercel/next.js into koukou
11koukou Jan 15, 2022
f2c026f
Merge branch 'koukou' of https://github.com/11koukou/next.js into koukou
11koukou Jan 15, 2022
890afb6
Merge branch 'canary' into koukou
11koukou Jan 16, 2022
cd76b61
Merge branch 'canary' into koukou
11koukou Jan 17, 2022
12dc7cb
Merge branch 'canary' into koukou
11koukou Jan 18, 2022
731f9f1
Merge branch 'canary' into koukou
11koukou Jan 20, 2022
b973e58
Merge branch 'canary' into koukou
11koukou Jan 20, 2022
14f9b5f
added test, fixed initial root detection
11koukou Jan 23, 2022
12c2ccc
Merge branch 'canary' into koukou
11koukou Jan 23, 2022
c50d278
Merge branch 'canary' into koukou
11koukou Jan 24, 2022
fe55cc5
Update test/integration/image-component/default/test/index.test.js
11koukou Jan 24, 2022
b49c235
prop names changed
11koukou Jan 24, 2022
7583a1b
added 'lazyroot' prop to the documentation
11koukou Jan 24, 2022
577e566
Merge branch 'canary' into koukou
11koukou Jan 24, 2022
8a84282
removed unused import
11koukou Jan 24, 2022
49d49d3
Apply suggestions from code review
styfle Jan 24, 2022
e62e3f1
Update docs with lazyRoot added in 12.0.9
styfle Jan 24, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions packages/next/client/image.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,7 @@ export type ImageProps = Omit<
quality?: number | string
priority?: boolean
loading?: LoadingValue
lazyRoot?: React.RefObject<HTMLElement> | null
lazyBoundary?: string
placeholder?: PlaceholderValue
blurDataURL?: string
Expand Down Expand Up @@ -315,6 +316,7 @@ export default function Image({
unoptimized = false,
priority = false,
loading,
lazyRoot = null,
lazyBoundary = '200px',
className,
quality,
Expand Down Expand Up @@ -505,6 +507,7 @@ export default function Image({
}

const [setRef, isIntersected] = useIntersection<HTMLImageElement>({
root: lazyRoot?.current,
rootMargin: lazyBoundary,
disabled: !isLazy,
})
Expand Down
11 changes: 8 additions & 3 deletions packages/next/client/use-intersection.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,11 @@ import {
cancelIdleCallback,
} from './request-idle-callback'

type UseIntersectionObserverInit = Pick<IntersectionObserverInit, 'rootMargin'>
type UseIntersectionObserverInit = Pick<
IntersectionObserverInit,
'rootMargin' | 'root'
>

type UseIntersection = { disabled?: boolean } & UseIntersectionObserverInit
type ObserveCallback = (isVisible: boolean) => void
type Observer = {
Expand All @@ -16,6 +20,7 @@ type Observer = {
const hasIntersectionObserver = typeof IntersectionObserver !== 'undefined'

export function useIntersection<T extends Element>({
root,
rootMargin,
disabled,
}: UseIntersection): [(element: T | null) => void, boolean] {
Expand All @@ -37,11 +42,11 @@ export function useIntersection<T extends Element>({
unobserve.current = observe(
el,
(isVisible) => isVisible && setVisible(isVisible),
{ rootMargin }
{ root, rootMargin }
)
}
},
[isDisabled, rootMargin, visible]
[isDisabled, root, rootMargin, visible]
)

useEffect(() => {
Expand Down