Files
remanso/src/views/RepoList.vue
Julien Calixte da4fada8a1 fix(repoList): handle Bad credentials error from GitHub API
Catch 401 responses in useRepos loadMore and expose hasCredentialError,
then show a sign-in prompt in RepoList instead of an unhandled rejection.
2026-04-27 10:32:37 +02:00

122 lines
3.2 KiB
Vue

<script lang="ts" setup>
import { vInfiniteScroll } from "@vueuse/components"
import GoBack from "@/components/GoBack.vue"
import SignInGithub from "@/components/SignInGithub.vue"
import { useGitHubLogin } from "@/hooks/useGitHubLogin.hook"
import { useRepos } from "@/hooks/useRepos.hook"
import { useRepoList } from "@/modules/repo/hooks/useRepoList.hook"
const { username } = useGitHubLogin()
const { isReady, hasCredentialError } = useRepos()
const {
favoriteRepos,
otherRepos,
favoriteCheckboxes,
toggleCheckbox,
canLoadMore,
loadMore
} = useRepoList()
</script>
<template>
<div
class="repo-list"
v-infinite-scroll="[loadMore, { canLoadMore: () => canLoadMore }]"
>
<h1 class="title is-1">Repositories</h1>
<go-back />
<div v-if="!isReady">loading...</div>
<div v-else-if="hasCredentialError">
<p>Your GitHub credentials are invalid or expired.</p>
<sign-in-github />
</div>
<div v-else class="columns is-centered">
<div class="column is-one-third">
<table
v-if="favoriteRepos.length > 0"
class="table is-striped is-hoverable"
>
<thead>
<tr>
<th></th>
<th>Favorites</th>
</tr>
</thead>
<tbody>
<tr v-for="repo in favoriteRepos" :key="repo.id">
<td>
<input
type="checkbox"
name="favorites"
class="checkbox"
:value="repo.id"
:checked="favoriteCheckboxes.includes(repo.id)"
@click="toggleCheckbox(repo)"
/>
</td>
<td>
<span v-if="repo.isPrivate">🔏</span>
<router-link
:to="{
name: 'FluxNoteView',
params: { user: username, repo: repo.name }
}"
>{{ repo.name }}</router-link
>
</td>
</tr>
</tbody>
</table>
<br v-if="favoriteRepos.length > 0" />
<table class="table is-striped is-hoverable">
<thead>
<tr>
<th></th>
<th>Repos</th>
</tr>
</thead>
<tbody>
<tr v-for="repo in otherRepos" :key="repo.id">
<td>
<input
type="checkbox"
name="favorites"
class="checkbox"
:value="repo.id"
:checked="favoriteCheckboxes.includes(repo.id)"
@click="toggleCheckbox(repo)"
/>
</td>
<td>
<router-link
:to="{
name: 'FluxNoteView',
params: { user: username, repo: repo.name }
}"
>{{ repo.name }}</router-link
>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</template>
<style lang="scss" scoped>
.repo-list {
flex: 1;
padding: 1rem;
text-align: center;
overflow-y: auto;
table {
margin: auto;
}
}
</style>