[miniProjects] 28_Github Profiles

๋ณด๋ฆฌยท2023๋…„ 6์›” 16์ผ

miniProjects

๋ชฉ๋ก ๋ณด๊ธฐ
28/47

28_Github Profiles

๐Ÿ’ป ์ฃผ์ œ : ๊นƒํ—ˆ๋ธŒ API๋กœ ์‚ฌ์šฉ์ž๋ฅผ ๋ถˆ๋Ÿฌ์™€ ์‚ฌ์šฉ์ž๋ฅผ ๊ฒ€์ƒ‰ํ•ด ํ”„๋กœํ•„ ๋ฐ์ดํ„ฐ๋ฅผ ์–ป์–ด ์นด๋“œ์— ํ‘œ์‹œํ•จ. ๋˜ํ•œ, ์‚ฌ์šฉ์ž์˜ ์ตœ์‹  ๋ฆฌํฌ์ง€ํ† ๋ฆฌ 5๊ฐœ๋ฅผ ๋ณด์—ฌ์คŒ.

const APIURL = 'https://api.github.com/users/'

const main = document.getElementById('main')
const form = document.getElementById('form')
const search = document.getElementById('search')

async function getUser(username) {
    try {
        const { data } = await axios(APIURL + username)

        createUserCard(data)
        getRepos(username)
    } catch(err) {
        if(err.response.status == 404) {
            createErrorCard('์ด ์ด๋ฆ„์„ ๊ฐ€์ง„ ์‚ฌ์šฉ์ž๊ฐ€ ์—†์Šต๋‹ˆ๋‹ค.')
        }
    }
}

async function getRepos(username) {
    try {
        const { data } = await axios(APIURL + username + '/repos?sort=created')

        addReposToCard(data)
    } catch(err) {
        createErrorCard('Problem fetching repos')
    }
}

function createUserCard(user) {
    const userID = user.name || user.login
    const userBio = user.bio ? `<p>${user.bio}</p>` : ''
    const cardHTML = `
    <div class="card">
    <div>
      <img src="${user.avatar_url}" alt="${user.name}" class="avatar">
    </div>
    <div class="user-info">
      <h2>${userID}</h2>
      ${userBio}
      <ul>
        <li>${user.followers} <strong>Followers</strong></li>
        <li>${user.following} <strong>Following</strong></li>
        <li>${user.public_repos} <strong>Repos</strong></li>
      </ul>

      <div id="repos"></div>
    </div>
  </div>
    `
    main.innerHTML = cardHTML
    
}

function createErrorCard(msg) {
    const cardHTML = `
        <div class="card">
            <h1>${msg}</h1>
        </div>
    `

    main.innerHTML = cardHTML
}

function addReposToCard(repos) {
    const reposEl = document.getElementById('repos')

    repos
        .slice(0, 5)
        .forEach(repo => {
            const repoEl = document.createElement('a')
            repoEl.classList.add('repo')
            repoEl.href = repo.html_url
            repoEl.target = '_blank'
            repoEl.innerText = repo.name

            reposEl.appendChild(repoEl)
        })
}

form.addEventListener('submit', (e) => {
    e.preventDefault()

    const user = search.value

    if(user) {
        getUser(user)

        search.value = ''
    }
})
  • APIURL ๋ณ€์ˆ˜๋Š” GitHub API์˜ ๊ธฐ๋ณธ URL์„ ์ €์žฅํ•œ๋‹ค.
  • getUser ํ•จ์ˆ˜๋Š” ์‚ฌ์šฉ์ž ์ด๋ฆ„์„ ์ธ์ˆ˜๋กœ ๋ฐ›์•„ ํ•ด๋‹น ์‚ฌ์šฉ์ž์˜ ํ”„๋กœํ•„ ์ •๋ณด๋ฅผ ๊ฐ€์ ธ์˜ค๋Š” ์—ญํ• ์„ ํ•œ๋‹ค. axios๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ API ์š”์ฒญ์„ ๋ณด๋‚ด๊ณ , ๊ฐ€์ ธ์˜จ ๋ฐ์ดํ„ฐ๋ฅผ createUserCard ํ•จ์ˆ˜์— ์ „๋‹ฌํ•˜์—ฌ ์‚ฌ์šฉ์ž ์นด๋“œ๋ฅผ ์ƒ์„ฑํ•œ๋‹ค. ๋˜ํ•œ, getRepos ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•˜์—ฌ ์‚ฌ์šฉ์ž์˜ ๋ ˆํฌ์ง€ํ† ๋ฆฌ ์ •๋ณด๋ฅผ ๊ฐ€์ ธ์˜จ๋‹ค. ์—๋Ÿฌ ์ฒ˜๋ฆฌ๋ฅผ ์œ„ํ•ด try-catch ๋ฌธ์„ ์‚ฌ์šฉํ•˜๊ณ , 404 ์ƒํƒœ ์ฝ”๋“œ์ผ ๊ฒฝ์šฐ์—๋Š” "์ด ์ด๋ฆ„์„ ๊ฐ€์ง„ ์‚ฌ์šฉ์ž๊ฐ€ ์—†์Šต๋‹ˆ๋‹ค." ์˜ค๋ฅ˜ ๋ฉ”์‹œ์ง€๋ฅผ ์ƒ์„ฑํ•œ๋‹ค.
  • getRepos ํ•จ์ˆ˜๋Š” ์‚ฌ์šฉ์ž ์ด๋ฆ„์„ ์ธ์ˆ˜๋กœ ๋ฐ›์•„ ํ•ด๋‹น ์‚ฌ์šฉ์ž์˜ ๋ ˆํฌ์ง€ํ† ๋ฆฌ ์ •๋ณด๋ฅผ ๊ฐ€์ ธ์˜ค๋Š” ์—ญํ• ์„ ํ•œ๋‹ค. axios๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ API ์š”์ฒญ์„ ๋ณด๋‚ด๊ณ , ๊ฐ€์ ธ์˜จ ๋ฐ์ดํ„ฐ๋ฅผ addReposToCard ํ•จ์ˆ˜์— ์ „๋‹ฌํ•˜์—ฌ ๋ ˆํฌ์ง€ํ† ๋ฆฌ ์นด๋“œ๋ฅผ ์ƒ์„ฑํ•œ๋‹ค. ์—๋Ÿฌ ์ฒ˜๋ฆฌ๋ฅผ ์œ„ํ•ด try-catch ๋ฌธ์„ ์‚ฌ์šฉํ•˜๊ณ , ์—๋Ÿฌ ๋ฐœ์ƒ ์‹œ "Problem fetching repos" ์˜ค๋ฅ˜ ๋ฉ”์‹œ์ง€๋ฅผ ์ƒ์„ฑํ•œ๋‹ค.
  • createUserCard ํ•จ์ˆ˜๋Š” ์ฃผ์–ด์ง„ ์‚ฌ์šฉ์ž ์ •๋ณด๋ฅผ ๊ธฐ๋ฐ˜์œผ๋กœ ์‚ฌ์šฉ์ž ์นด๋“œ๋ฅผ HTML ํ˜•์‹์œผ๋กœ ์ƒ์„ฑํ•˜์—ฌ main ์š”์†Œ์— ์‚ฝ์ž…ํ•œ๋‹ค.
  • addReposToCard ํ•จ์ˆ˜๋Š” ์ฃผ์–ด์ง„ ๋ ˆํฌ์ง€ํ† ๋ฆฌ ๋ฐฐ์—ด์„ ์‚ฌ์šฉํ•˜์—ฌ ๋ ˆํฌ์ง€ํ† ๋ฆฌ ๋งํฌ๋ฅผ ์‚ฌ์šฉ์ž ์นด๋“œ์— ์ถ”๊ฐ€ํ•œ๋‹ค.
  • createErrorCard ํ•จ์ˆ˜๋Š” ์ฃผ์–ด์ง„ ๋ฉ”์‹œ์ง€๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์—๋Ÿฌ ์นด๋“œ๋ฅผ ์ƒ์„ฑํ•˜์—ฌ main ์š”์†Œ์— ์‚ฝ์ž…ํ•œ๋‹ค.
  • form ์š”์†Œ์˜ submit ์ด๋ฒคํŠธ์— ๋Œ€ํ•œ ์ด๋ฒคํŠธ ๋ฆฌ์Šค๋„ˆ๊ฐ€ ๋“ฑ๋ก๋˜์–ด ์žˆ์œผ๋ฉฐ, ์‚ฌ์šฉ์ž๊ฐ€ ๊ฒ€์ƒ‰ ํผ์„ ์ œ์ถœํ•˜๋ฉด ์ž…๋ ฅ๋œ ์‚ฌ์šฉ์ž ์ด๋ฆ„์œผ๋กœ getUser ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•˜์—ฌ ์‚ฌ์šฉ์ž ์ •๋ณด๋ฅผ ๊ฒ€์ƒ‰ํ•œ๋‹ค. ๊ฒ€์ƒ‰ ํผ์ด ์ œ์ถœ๋œ ํ›„์—๋Š” ๊ฒ€์ƒ‰ ํ•„๋“œ๊ฐ€ ์ดˆ๊ธฐํ™”๋œ๋‹ค.
๐Ÿ‘๐Ÿป ๊นƒํ—ˆ๋ธŒ ์‚ฌ์šฉ์ž API

https://api.github.com/users/ ๋’ค์— ๊ฒ€์ƒ‰ ์ฐฝ์— ์ž…๋ ฅ๋œ ์‚ฌ์šฉ์ž ID๊ฐ€ ๋“ค์–ด๊ฐ
์•„๋ž˜ ์ด๋ฏธ์ง€๋Š” ๋‚˜์˜ ๊นƒํ—ˆ๋ธŒ id๋ฅผ ์ž…๋ ฅํ–ˆ์„ ๋•Œ ๋‚˜์˜ค๋Š” ์ •๋ณด์ž„.

profile
์ •์‹ ์ฐจ๋ ค ์ด ๊ฐ๋ฐ•ํ•œ ์„ธ์ƒ์†์—์„œ

0๊ฐœ์˜ ๋Œ“๊ธ€