♻️ (store) use a store to store readme and files
This commit is contained in:
77
src/modules/repo/services/repo.ts
Normal file
77
src/modules/repo/services/repo.ts
Normal file
@@ -0,0 +1,77 @@
|
||||
import { useGitHubLogin } from '@/hooks/useGitHubLogin.hook'
|
||||
import { useMarkdown } from '@/hooks/useMarkdown.hook'
|
||||
import { useNoteCache } from '@/modules/note/hooks/useNoteCache'
|
||||
import { RepoFile } from '@/modules/repo/interfaces/RepoFile'
|
||||
import { Octokit } from '@octokit/rest'
|
||||
|
||||
export const getFiles = async (
|
||||
owner: string,
|
||||
repo: string
|
||||
): Promise<RepoFile[]> => {
|
||||
if (!owner || !repo) {
|
||||
return []
|
||||
}
|
||||
|
||||
const { accessToken } = useGitHubLogin()
|
||||
|
||||
const octokit = new Octokit({
|
||||
auth: accessToken.value
|
||||
})
|
||||
|
||||
const commits = await octokit.request('GET /repos/{owner}/{repo}/commits', {
|
||||
owner,
|
||||
repo
|
||||
})
|
||||
|
||||
const lastCommit = commits.data.shift()
|
||||
|
||||
if (!lastCommit) {
|
||||
return []
|
||||
}
|
||||
|
||||
const treeResponse = await octokit.request(
|
||||
'GET /repos/{owner}/{repo}/git/trees/{tree_sha}',
|
||||
{
|
||||
owner,
|
||||
repo,
|
||||
tree_sha: lastCommit.commit.tree.sha,
|
||||
recursive: 'true'
|
||||
}
|
||||
)
|
||||
|
||||
return treeResponse?.data.tree.filter((t) => t.type === 'blob') ?? []
|
||||
}
|
||||
|
||||
export const getMainReadme = async (owner: string, repo: string) => {
|
||||
if (!owner || !repo) {
|
||||
return null
|
||||
}
|
||||
const { render } = useMarkdown()
|
||||
const { getCachedNote, saveCacheNote } = useNoteCache('README')
|
||||
|
||||
const cachedReadme = await getCachedNote()
|
||||
|
||||
try {
|
||||
const { accessToken } = useGitHubLogin()
|
||||
const octokit = new Octokit({
|
||||
auth: accessToken.value
|
||||
})
|
||||
|
||||
const README = await octokit.repos.getReadme({
|
||||
owner,
|
||||
repo
|
||||
})
|
||||
|
||||
if (README) {
|
||||
saveCacheNote(README.data.content)
|
||||
return render(README.data.content)
|
||||
}
|
||||
} catch (error) {
|
||||
console.warn(error)
|
||||
if (cachedReadme) {
|
||||
return render(cachedReadme.content)
|
||||
}
|
||||
}
|
||||
|
||||
return null
|
||||
}
|
||||
Reference in New Issue
Block a user