Skip to content

Commit

Permalink
Merge pull request #2096 from inertiajs/when-visible-empty-default-slot
Browse files Browse the repository at this point in the history
Ensure we have a default slot for WhenVisible before executing it
  • Loading branch information
joetannenbaum authored Dec 3, 2024
2 parents 2d03ebc + 350262f commit b149e1b
Show file tree
Hide file tree
Showing 5 changed files with 34 additions and 3 deletions.
4 changes: 4 additions & 0 deletions packages/react/test-app/Pages/WhenVisible.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,5 +23,9 @@ export default () => (
<Foo label="Third one is visible!" />
</WhenVisible>
</div>

<div style={{ marginTop: '5000px' }}>
<WhenVisible data="foo" fallback={<div>Loading fourth one...</div>}></WhenVisible>
</div>
</>
)
8 changes: 8 additions & 0 deletions packages/svelte/test-app/Pages/WhenVisible.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -31,3 +31,11 @@
<div>Third one is visible!</div>
</WhenVisible>
</div>

<div style="margin-top: 5000px">
<WhenVisible data="foo">
<svelte:fragment slot="fallback">
<div>Loading fourth one...</div>
</svelte:fragment>
</WhenVisible>
</div>
6 changes: 3 additions & 3 deletions packages/vue3/src/whenVisible.ts
Original file line number Diff line number Diff line change
Expand Up @@ -94,10 +94,10 @@ export default defineComponent({
els.push(h(this.$props.as))
}

if (this.loaded) {
els.push(this.$slots.default())
} else {
if (!this.loaded) {
els.push(this.$slots.fallback ? this.$slots.fallback() : null)
} else if (this.$slots.default) {
els.push(this.$slots.default())
}

return els
Expand Down
8 changes: 8 additions & 0 deletions packages/vue3/test-app/Pages/WhenVisible.vue
Original file line number Diff line number Diff line change
Expand Up @@ -32,4 +32,12 @@ import { WhenVisible } from '@inertiajs/vue3'
<div>Third one is visible!</div>
</WhenVisible>
</div>

<div style="margin-top: 5000px">
<WhenVisible data="foo">
<template #fallback>
<div>Loading fourth one...</div>
</template>
</WhenVisible>
</div>
</template>
11 changes: 11 additions & 0 deletions tests/when-visible.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,9 @@ test('it will wait to fire the reload until element is visible', async ({ page }

await page.evaluate(() => (window as any).scrollTo(0, 5000))
await expect(page.getByText('Loading first one...')).toBeVisible()
await expect(page.getByText('First one is visible!')).not.toBeVisible()
await page.waitForResponse(page.url())
await expect(page.getByText('Loading first one...')).not.toBeVisible()
await expect(page.getByText('First one is visible!')).toBeVisible()

// Scroll back up and then back down, make sure we don't re-request
Expand All @@ -35,13 +37,17 @@ test('it will wait to fire the reload until element is visible', async ({ page }
// This one has a buffer of 1000
await page.evaluate(() => (window as any).scrollTo(0, 9000))
await expect(page.getByText('Loading second one...')).toBeVisible()
await expect(page.getByText('Second one is visible!')).not.toBeVisible()
await page.waitForResponse(page.url())
await expect(page.getByText('Loading second one...')).not.toBeVisible()
await expect(page.getByText('Second one is visible!')).toBeVisible()

// This one should trigger every time it's visible
await page.evaluate(() => (window as any).scrollTo(0, 15_000))
await expect(page.getByText('Loading third one...')).toBeVisible()
await expect(page.getByText('Third one is visible!')).not.toBeVisible()
await page.waitForResponse(page.url())
await expect(page.getByText('Loading third one...')).not.toBeVisible()
await expect(page.getByText('Third one is visible!')).toBeVisible()

// Now scroll up and down to re-trigger it
Expand All @@ -58,4 +64,9 @@ test('it will wait to fire the reload until element is visible', async ({ page }
await page.evaluate(() => (window as any).scrollTo(0, 15_000))
await expect(page.getByText('Third one is visible!')).toBeVisible()
await page.waitForResponse(page.url())

await page.evaluate(() => (window as any).scrollTo(0, 20_000))
await expect(page.getByText('Loading fourth one...')).toBeVisible()
await page.waitForResponse(page.url())
await expect(page.getByText('Loading fourth one...')).not.toBeVisible()
})

0 comments on commit b149e1b

Please sign in to comment.