mirror of
https://github.com/Steffo99/steffoweb.git
synced 2024-11-21 23:54:30 +00:00
32 lines
No EOL
826 B
TypeScript
32 lines
No EOL
826 B
TypeScript
import React from "react"
|
|
|
|
|
|
export function useGitHubRepositories(user: string) {
|
|
const [data, setData] = React.useState<any[]>([])
|
|
|
|
const fetchData = React.useCallback(
|
|
async () => {
|
|
setData([])
|
|
let page = 1;
|
|
let count = 100;
|
|
while(count == 100) {
|
|
const resp = await fetch(`https://api.github.com/users/${user}/repos?per_page=100&page=${page}&sort=pushed&direction=desc`)
|
|
const data = await resp.json()
|
|
count = data.length
|
|
page += 1
|
|
setData((old) => [...old, ...data])
|
|
}
|
|
},
|
|
[]
|
|
)
|
|
|
|
React.useEffect(
|
|
() => {
|
|
// noinspection JSIgnoredPromiseFromCall
|
|
fetchData()
|
|
},
|
|
[fetchData]
|
|
)
|
|
|
|
return data
|
|
} |