Infinite scroll

This commit is contained in:
Adria Navarro 2023-09-22 13:51:08 +02:00
parent 7ad05930e1
commit b391ca37ab
4 changed files with 27 additions and 2 deletions

View File

@ -82,6 +82,7 @@
</script> </script>
<Picker <Picker
on:loadMore
{id} {id}
{error} {error}
{disabled} {disabled}

View File

@ -2,7 +2,7 @@
import "@spectrum-css/picker/dist/index-vars.css" import "@spectrum-css/picker/dist/index-vars.css"
import "@spectrum-css/popover/dist/index-vars.css" import "@spectrum-css/popover/dist/index-vars.css"
import "@spectrum-css/menu/dist/index-vars.css" import "@spectrum-css/menu/dist/index-vars.css"
import { createEventDispatcher } from "svelte" import { createEventDispatcher, onDestroy } from "svelte"
import clickOutside from "../../Actions/click_outside" import clickOutside from "../../Actions/click_outside"
import Search from "./Search.svelte" import Search from "./Search.svelte"
import Icon from "../../Icon/Icon.svelte" import Icon from "../../Icon/Icon.svelte"
@ -43,10 +43,12 @@
export let align = "left" export let align = "left"
export let footer = null export let footer = null
export let customAnchor = null export let customAnchor = null
const dispatch = createEventDispatcher() const dispatch = createEventDispatcher()
let button let button
let popover let popover
let component
$: sortedOptions = getSortedOptions(options, getOptionLabel, sort) $: sortedOptions = getSortedOptions(options, getOptionLabel, sort)
$: filteredOptions = getFilteredOptions( $: filteredOptions = getFilteredOptions(
@ -89,6 +91,20 @@
} }
return options return options
} }
const onScroll = e => {
const scrollPxThreshold = 100
const scrollPositionFromBottom =
e.target.scrollHeight - e.target.clientHeight - e.target.scrollTop
if (scrollPositionFromBottom < scrollPxThreshold) {
dispatch("loadMore")
}
}
$: component?.addEventListener("scroll", onScroll)
onDestroy(() => {
component?.removeEventListener("scroll", null)
})
</script> </script>
<button <button
@ -168,7 +184,7 @@
placeholder="Search" placeholder="Search"
/> />
{/if} {/if}
<ul class="spectrum-Menu" role="listbox"> <ul class="spectrum-Menu" role="listbox" bind:this={component}>
{#if placeholderOption} {#if placeholderOption}
<li <li
class="spectrum-Menu-item placeholder" class="spectrum-Menu-item placeholder"

View File

@ -67,6 +67,7 @@
on:click on:click
bind:open bind:open
bind:searchTerm bind:searchTerm
on:loadMore
{quiet} {quiet}
{id} {id}
{error} {error}

View File

@ -118,6 +118,12 @@
onChange({ value }) onChange({ value })
} }
} }
const loadMore = () => {
if (!$fetch.loading) {
fetch.nextPage()
}
}
</script> </script>
<Field <Field
@ -138,6 +144,7 @@
{autocomplete} {autocomplete}
value={selectedValue} value={selectedValue}
on:change={multiselect ? multiHandler : singleHandler} on:change={multiselect ? multiHandler : singleHandler}
on:loadMore={loadMore}
id={fieldState.fieldId} id={fieldState.fieldId}
disabled={fieldState.disabled} disabled={fieldState.disabled}
error={fieldState.error} error={fieldState.error}