(favorite) save favorite repos

This commit is contained in:
2021-03-19 23:01:31 +01:00
parent 2faabb6c0e
commit 5fcf3c9df5
11 changed files with 308 additions and 44 deletions

View File

@@ -1,32 +1,88 @@
<template>
<div class="repo-list">
<h1>Repositories</h1>
<go-back />
<h1 class="title is-1">Repositories</h1>
<span v-if="!isReady">loading...</span>
<ul>
<li v-for="repo in repos" :key="repo">
<router-link
:to="{ name: 'Home', params: { user: username, repo: repo } }"
>
{{ repo }}
</router-link>
</li>
</ul>
<div v-else class="columns is-centered">
<div class="column is-one-third">
<table class="table is-striped is-hoverable is-fullwidth">
<tr v-for="repo in favoriteRepos" :key="repo.id">
<td>
<input
type="checkbox"
name="favorites"
:value="repo.id"
:checked="favoriteCheckboxes.includes(repo.id)"
@click="toggleCheckbox(repo)"
/>
</td>
<td>
<span v-if="repo.isPrivate">🔏</span>
<router-link
:to="{
name: 'Home',
params: { user: username, repo: repo.name }
}"
>
{{ repo.name }}
</router-link>
</td>
</tr>
<tr v-for="repo in otherRepos" :key="repo.id">
<td>
<input
type="checkbox"
name="favorites"
:value="repo.id"
:checked="favoriteCheckboxes.includes(repo.id)"
@click="toggleCheckbox(repo)"
/>
</td>
<td>
<router-link
:to="{
name: 'Home',
params: { user: username, repo: repo.name }
}"
>
{{ repo.name }}
</router-link>
</td>
</tr>
</table>
</div>
</div>
</div>
</template>
<script lang="ts">
import { defineComponent } from 'vue'
import { useRepos } from '@/hooks/useRepos.hook'
import { useGitHubLogin } from '@/hooks/useGitHubLogin.hook'
import { useRepoList } from '@/modules/repo/hooks/userRepoList.hook'
import { useRepos } from '@/hooks/useRepos.hook'
import GoBack from '@/components/GoBack.vue'
export default defineComponent({
name: 'RepoList',
components: { GoBack },
setup() {
const { username } = useGitHubLogin()
const { isReady } = useRepos()
const {
favoriteRepos,
otherRepos,
favoriteCheckboxes,
toggleCheckbox
} = useRepoList()
return {
...useRepos(),
username
isReady,
username,
favoriteRepos,
otherRepos,
favoriteCheckboxes,
toggleCheckbox
}
}
})
@@ -35,6 +91,9 @@ export default defineComponent({
<style lang="scss" scoped>
.repo-list {
flex: 1;
padding: 1rem;
text-align: center;
overflow-y: auto;
}
</style>