1.0.2 • Published 3 years ago

kokateam-infscroll v1.0.2

Weekly downloads
-
License
MIT
Repository
github
Last release
3 years ago

kokateam-infscroll

Модуль, позволяющий создать бесконечный скролл*.

Установка

$ yarn add kokateam-infscroll или $ npm i kokateam-infscroll

Пример использования

import InfScroll from 'kokateam-infscroll';

const App = () => {
  const [data,setData] = React.useState<number[]>([])
	const [showLoader, setShowLoader] = React.useState<boolean>(true)

	const changeData = () => {
		return new Promise(response=>{
			fetch(`https://ban.su/offset?offset=${data.length}&count=20`)
			.then(e=>e.json())
			.then(res=>{
				setData(e=>[...e,...res])
				response(true)
			})
			.catch(()=>{
				setShowLoader(false)
			})
		})
	}

	return <InfScroll onReachEnd={changeData} showLoader={showLoader}>
		{data.map((e,i)=><Card key={i} i={e}/>)}
	</InfScroll>
}

export default App;

Параметры

loader {any} - визуальный элемент подгрузки, располагающийся внизу.

showLoader {boolean} - переключатель отображения загрузки данных.

onReachEnd {()=>Promise<unknown>} - Promise функция, при достижении конца. Promise обязателен, во избежание дублирования данных.

triggerSize {string} - зона срабатывания функции, по умолчанию 50px от низа.