실습 - 5. 타입 정의

CHOYEAH·2023년 11월 5일
0

TypeScript

목록 보기
22/23

API 함수 타입 정의


  • 변환 과정
    function fetchCovidSummary() {
      const url = 'https://api.covid19api.com/summary';
      return axios.get(url);
    }
    
    // 변환 후
    
    interface Country {
      Country: string;
      CountryCode: string;
      Date: string;
      ID: string;
      NewConfirmed: number;
      NewDeaths: number;
      NewRecovered: number;
      Premium: any;
      Slug: string;
      TotalConfirmed: number;
      TotalDeaths: number;
      TotalRecovered: number;
    }
    
    interface Global {
      Date: string;
      NewConfirmed: number;
      NewDeaths: number;
      NewRecovered: number;
      TotalConfirmed: number;
      TotalDeaths: number;
      TotalRecovered: number;
    }
    
    export interface CovidSummaryResponse {
      Countries: Country[];
      Date: string;
      Global: Global;
      Message: string;
    }
    
    // api
    function fetchCovidSummary(): Promise<AxiosResponse<CovidSummaryResponse>> {
      const url = 'https://api.covid19api.com/summary';
      return axios.get(url);
    }
    function fetchCountryInfo(countryCode: string, status: CovidStatus) {
      // params: confirmed, recovered, deaths
      const url = `https://api.covid19api.com/country/${countryCode}/status/${status}`;
      return axios.get(url);
    }
    
    // 변환 후
    
    interface CountrySummaryInfo {
      Cases: number;
      City: string;
      CityCode: string;
      Country: string;
      CountryCode: string;
      Date: string;
      Lat: string;
      Lon: string;
      Province: string;
      Status: string;
    }
    
    // 배열을 담기 때문에 인터페이스가 아닌 타입으로 지정
    export type CountrySummaryResponse = CountrySummaryInfo[];
    
    function fetchCountryInfo(
      countryName: string,
      status: CovidStatus
    ): Promise<AxiosResponse<CountrySummaryResponse>> {
      // status: confirmed, recovered, deaths
      const url = `https://api.covid19api.com/country/${countryName}/status/${status}`;
      return axios.get(url);
    }
    function setTotalConfirmedNumber(data: any) {
      confirmedTotal.innerText = data.Countries.reduce(
        (total: any, current: any) => (total += current.TotalConfirmed),
        0
      );
    }
    
    function setTotalDeathsByWorld(data: any) {
      deathsTotal.innerText = data.Countries.reduce(
        (total: any, current: any) => (total += current.TotalDeaths),
        0
      );
    }
    
    function setTotalRecoveredByWorld(data: any) {
      recoveredTotal.innerText = data.Countries.reduce(
        (total: any, current: any) => (total += current.TotalRecovered),
        0
      );
    }
    
    // 변환 후
    
    function setTotalConfirmedNumber(data: CovidSummaryResponse) {
      confirmedTotal.innerText = data.Countries.reduce(
        (total: number, current: Country) => (total += current.TotalConfirmed),
        0
      ).toString();
    }
    
    function setTotalDeathsByWorld(data: CovidSummaryResponse) {
      deathsTotal.innerText = data.Countries.reduce(
        (total: number, current: Country) => (total += current.TotalDeaths),
        0
      ).toString();
    }
    
    function setTotalRecoveredByWorld(data: CovidSummaryResponse) {
      recoveredTotal.innerText = data.Countries.reduce(
        (total: number, current: Country) => (total += current.TotalRecovered),
        0
      ).toString();
    }
    
    function setCountryRanksByConfirmedCases(data: any) {
      const sorted = data.Countries.sort(
        (a: any, b: any) => b.TotalConfirmed - a.TotalConfirmed
      );
      sorted.forEach((value: any) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item flex align-center');
        li.setAttribute('id', value.Slug);
        const span = document.createElement('span');
        span.textContent = value.TotalConfirmed;
        span.setAttribute('class', 'cases');
        const p = document.createElement('p');
        p.setAttribute('class', 'country');
        p.textContent = value.Country;
        li.appendChild(span);
        li.appendChild(p);
        rankList.appendChild(li);
      });
    }
    
    function setLastUpdatedTimestamp(data: any) {
      lastUpdatedTime.innerText = new Date(data.Date).toLocaleString();
    }
    
    // 변환 후
    
    function setCountryRanksByConfirmedCases(data: CovidSummaryResponse) {
      const sorted = data.Countries.sort(
        (a: Country, b: Country) => b.TotalConfirmed - a.TotalConfirmed
      );
      sorted.forEach((value: Country) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item flex align-center');
        li.setAttribute('id', value.Slug);
        const span = document.createElement('span');
        span.textContent = value.TotalConfirmed.toString();
        span.setAttribute('class', 'cases');
        const p = document.createElement('p');
        p.setAttribute('class', 'country');
        p.textContent = value.Country;
        li.appendChild(span);
        li.appendChild(p);
        rankList.appendChild(li);
      });
    }
    
    function setLastUpdatedTimestamp(data: CovidSummaryResponse) {
      lastUpdatedTime.innerText = new Date(data.Date).toLocaleString();
    }
    function getUnixTimestamp(date: Date) {
      return new Date(date).getTime();
    }
    
    function setDeathsList(data: any) {
      const sorted = data.sort(
        (a: any, b: any) => getUnixTimestamp(b.Date) - getUnixTimestamp(a.Date)
      );
      sorted.forEach((value: any) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item-b flex align-center');
        const span = document.createElement('span');
        span.textContent = value.Cases;
        span.setAttribute('class', 'deaths');
        const p = document.createElement('p');
        p.textContent = new Date(value.Date).toLocaleDateString().slice(0, -1);
        li.appendChild(span);
        li.appendChild(p);
        deathsList.appendChild(li);
      });
    }
    
    // 변환 후
    
    function getUnixTimestamp(date: Date | string) {
      return new Date(date).getTime();
    }
    
    function setDeathsList(data: CountrySummaryResponse) {
      const sorted = data.sort(
        (a: CountrySummaryInfo, b: CountrySummaryInfo) =>
          getUnixTimestamp(b.Date) - getUnixTimestamp(a.Date)
      );
      sorted.forEach((value: CountrySummaryInfo) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item-b flex align-center');
        const span = document.createElement('span');
        span.textContent = value.Cases.toString();
        span.setAttribute('class', 'deaths');
        const p = document.createElement('p');
        p.textContent = new Date(value.Date).toLocaleDateString().slice(0, -1);
        li.appendChild(span);
        li.appendChild(p);
        deathsList.appendChild(li);
      });
    }
    function setTotalDeathsByCountry(data: any) {
      deathsTotal.innerText = data[0].Cases;
    }
    
    function setRecoveredList(data: any) {
      const sorted = data.sort(
        (a: any, b: any) => getUnixTimestamp(b.Date) - getUnixTimestamp(a.Date)
      );
      sorted.forEach((value: any) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item-b flex align-center');
        const span = document.createElement('span');
        span.textContent = value.Cases;
        span.setAttribute('class', 'recovered');
        const p = document.createElement('p');
        p.textContent = new Date(value.Date).toLocaleDateString().slice(0, -1);
        li.appendChild(span);
        li.appendChild(p);
        recoveredList.appendChild(li);
      });
    }
    
    function setTotalRecoveredByCountry(data: any) {
      recoveredTotal.innerText = data[0].Cases;
    }
    
    // 변환 후
    
    function setTotalDeathsByCountry(data: CountrySummaryResponse) {
      deathsTotal.innerText = data[0].Cases.toString();
    }
    
    function setRecoveredList(data: CountrySummaryResponse) {
      const sorted = data.sort(
        (a: CountrySummaryInfo, b: CountrySummaryInfo) =>
          getUnixTimestamp(b.Date) - getUnixTimestamp(a.Date)
      );
      sorted.forEach((value: CountrySummaryInfo) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item-b flex align-center');
        const span = document.createElement('span');
        span.textContent = value.Cases.toString();
        span.setAttribute('class', 'recovered');
        const p = document.createElement('p');
        p.textContent = new Date(value.Date).toLocaleDateString().slice(0, -1);
        li.appendChild(span);
        li.appendChild(p);
        recoveredList.appendChild(li);
      });
    }
    
    function setTotalRecoveredByCountry(data: CountrySummaryResponse) {
      recoveredTotal.innerText = data[0].Cases.toString();
    }

차트 라이브러리 타입 정의


  • 변환 과정
    
    function setChartData(data: any) {
      const chartData = data.slice(-14).map((value: any) => value.Cases);
      const chartLabel = data
        .slice(-14)
        .map((value: any) =>
          new Date(value.Date).toLocaleDateString().slice(5, -1)
        );
      renderChart(chartData, chartLabel);
    }
    
    function renderChart(data: any, labels: any) {
      const ctx = $('#lineChart').getContext('2d');
      Chart.defaults.color = '#f5eaea';
      Chart.defaults.font.family = 'Exo 2';
      new Chart(ctx, {
        type: 'line',
        data: {
          labels,
          datasets: [
            {
              label: 'Confirmed for the last two weeks',
              backgroundColor: '#feb72b',
              borderColor: '#feb72b',
              data,
            },
          ],
        },
        options: {},
      });
    }
    
    // 변환 후
    
    function setChartData(data: CountrySummaryResponse) {
      const chartData = data
        .slice(-14)
        .map((value: CountrySummaryInfo) => value.Cases);
    
      const chartLabel = data
        .slice(-14)
        .map((value: CountrySummaryInfo) =>
          new Date(value.Date).toLocaleDateString().slice(5, -1)
        );
      renderChart(chartData, chartLabel);
    }
    
    function renderChart(data: number[], labels: string[]) {
      const lineChart = $('#lineChart') as HTMLCanvasElement;
      const ctx = lineChart.getContext('2d');
      Chart.defaults.color = '#f5eaea';
      Chart.defaults.font.family = 'Exo 2';
      new Chart(ctx, {
        type: 'line',
        data: {
          labels,
          datasets: [
            {
              label: 'Confirmed for the last two weeks',
              backgroundColor: '#feb72b',
              borderColor: '#feb72b',
              data,
            },
          ],
        },
        options: {},
      });
    }

변환 전/후 전체 코드


  • 변환 전 전체 코드
    import axios from 'axios';
    import { Chart } from 'chart.js';
    
    // utils
    function $(selector: string) {
      return document.querySelector(selector);
    }
    function getUnixTimestamp(date: Date) {
      return new Date(date).getTime();
    }
    
    // DOM
    const confirmedTotal = $('.confirmed-total') as HTMLSpanElement;
    const deathsTotal = $('.deaths') as HTMLParagraphElement;
    const recoveredTotal = $('.recovered') as HTMLParagraphElement;
    const lastUpdatedTime = $('.last-updated-time') as HTMLParagraphElement;
    const rankList = $('.rank-list');
    const deathsList = $('.deaths-list') as HTMLOListElement;
    const recoveredList = $('.recovered-list') as HTMLOListElement;
    const deathSpinner = createSpinnerElement('deaths-spinner');
    const recoveredSpinner = createSpinnerElement('recovered-spinner');
    
    function createSpinnerElement(id: string) {
      const wrapperDiv = document.createElement('div');
      wrapperDiv.setAttribute('id', id);
      wrapperDiv.setAttribute(
        'class',
        'spinner-wrapper flex justify-center align-center'
      );
      const spinnerDiv = document.createElement('div');
      spinnerDiv.setAttribute('class', 'ripple-spinner');
      spinnerDiv.appendChild(document.createElement('div'));
      spinnerDiv.appendChild(document.createElement('div'));
      wrapperDiv.appendChild(spinnerDiv);
      return wrapperDiv;
    }
    
    // state
    let isDeathLoading = false;
    const isRecoveredLoading = false;
    
    // api
    function fetchCovidSummary() {
      const url = 'https://api.covid19api.com/summary';
      return axios.get(url);
    }
    
    enum CovidStatus {
      Confirmed = 'confirmed',
      Recovered = 'recovered',
      Deaths = 'deaths',
    }
    function fetchCountryInfo(countryCode: string, status: CovidStatus) {
      // params: confirmed, recovered, deaths
      const url = `https://api.covid19api.com/country/${countryCode}/status/${status}`;
      return axios.get(url);
    }
    
    // methods
    function startApp() {
      setupData();
      initEvents();
    }
    
    // events
    function initEvents() {
      rankList.addEventListener('click', handleListClick);
    }
    
    async function handleListClick(event: any) {
      let selectedId;
      if (
        event.target instanceof HTMLParagraphElement ||
        event.target instanceof HTMLSpanElement
      ) {
        selectedId = event.target.parentElement.id;
      }
      if (event.target instanceof HTMLLIElement) {
        selectedId = event.target.id;
      }
      if (isDeathLoading) {
        return;
      }
      clearDeathList();
      clearRecoveredList();
      startLoadingAnimation();
      isDeathLoading = true;
      const { data: deathResponse } = await fetchCountryInfo(
        selectedId,
        CovidStatus.Deaths
      );
      const { data: recoveredResponse } = await fetchCountryInfo(
        selectedId,
        CovidStatus.Recovered
      );
      const { data: confirmedResponse } = await fetchCountryInfo(
        selectedId,
        CovidStatus.Confirmed
      );
      endLoadingAnimation();
      setDeathsList(deathResponse);
      setTotalDeathsByCountry(deathResponse);
      setRecoveredList(recoveredResponse);
      setTotalRecoveredByCountry(recoveredResponse);
      setChartData(confirmedResponse);
      isDeathLoading = false;
    }
    
    function setDeathsList(data: any) {
      const sorted = data.sort(
        (a: any, b: any) => getUnixTimestamp(b.Date) - getUnixTimestamp(a.Date)
      );
      sorted.forEach((value: any) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item-b flex align-center');
        const span = document.createElement('span');
        span.textContent = value.Cases;
        span.setAttribute('class', 'deaths');
        const p = document.createElement('p');
        p.textContent = new Date(value.Date).toLocaleDateString().slice(0, -1);
        li.appendChild(span);
        li.appendChild(p);
        deathsList.appendChild(li);
      });
    }
    
    function clearDeathList() {
      deathsList.innerHTML = null;
    }
    
    function setTotalDeathsByCountry(data: any) {
      deathsTotal.innerText = data[0].Cases;
    }
    
    function setRecoveredList(data: any) {
      const sorted = data.sort(
        (a: any, b: any) => getUnixTimestamp(b.Date) - getUnixTimestamp(a.Date)
      );
      sorted.forEach((value: any) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item-b flex align-center');
        const span = document.createElement('span');
        span.textContent = value.Cases;
        span.setAttribute('class', 'recovered');
        const p = document.createElement('p');
        p.textContent = new Date(value.Date).toLocaleDateString().slice(0, -1);
        li.appendChild(span);
        li.appendChild(p);
        recoveredList.appendChild(li);
      });
    }
    
    function clearRecoveredList() {
      recoveredList.innerHTML = null;
    }
    
    function setTotalRecoveredByCountry(data: any) {
      recoveredTotal.innerText = data[0].Cases;
    }
    
    function startLoadingAnimation() {
      deathsList.appendChild(deathSpinner);
      recoveredList.appendChild(recoveredSpinner);
    }
    
    function endLoadingAnimation() {
      deathsList.removeChild(deathSpinner);
      recoveredList.removeChild(recoveredSpinner);
    }
    
    async function setupData() {
      const { data } = await fetchCovidSummary();
      setTotalConfirmedNumber(data);
      setTotalDeathsByWorld(data);
      setTotalRecoveredByWorld(data);
      setCountryRanksByConfirmedCases(data);
      setLastUpdatedTimestamp(data);
    }
    
    function renderChart(data: any, labels: any) {
      const ctx = $('#lineChart').getContext('2d');
      Chart.defaults.color = '#f5eaea';
      Chart.defaults.font.family = 'Exo 2';
      new Chart(ctx, {
        type: 'line',
        data: {
          labels,
          datasets: [
            {
              label: 'Confirmed for the last two weeks',
              backgroundColor: '#feb72b',
              borderColor: '#feb72b',
              data,
            },
          ],
        },
        options: {},
      });
    }
    
    function setChartData(data: any) {
      const chartData = data.slice(-14).map((value: any) => value.Cases);
      const chartLabel = data
        .slice(-14)
        .map((value: any) =>
          new Date(value.Date).toLocaleDateString().slice(5, -1)
        );
      renderChart(chartData, chartLabel);
    }
    
    function setTotalConfirmedNumber(data: any) {
      confirmedTotal.innerText = data.Countries.reduce(
        (total: any, current: any) => (total += current.TotalConfirmed),
        0
      );
    }
    
    function setTotalDeathsByWorld(data: any) {
      deathsTotal.innerText = data.Countries.reduce(
        (total: any, current: any) => (total += current.TotalDeaths),
        0
      );
    }
    
    function setTotalRecoveredByWorld(data: any) {
      recoveredTotal.innerText = data.Countries.reduce(
        (total: any, current: any) => (total += current.TotalRecovered),
        0
      );
    }
    
    function setCountryRanksByConfirmedCases(data: any) {
      const sorted = data.Countries.sort(
        (a: any, b: any) => b.TotalConfirmed - a.TotalConfirmed
      );
      sorted.forEach((value: any) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item flex align-center');
        li.setAttribute('id', value.Slug);
        const span = document.createElement('span');
        span.textContent = value.TotalConfirmed;
        span.setAttribute('class', 'cases');
        const p = document.createElement('p');
        p.setAttribute('class', 'country');
        p.textContent = value.Country;
        li.appendChild(span);
        li.appendChild(p);
        rankList.appendChild(li);
      });
    }
    
    function setLastUpdatedTimestamp(data: any) {
      lastUpdatedTime.innerText = new Date(data.Date).toLocaleString();
    }
    
    startApp();
  • 변환 후 전체 코드
    import axios, { AxiosResponse } from 'axios';
    import { Chart } from 'chart.js';
    import {
      CovidSummaryResponse,
      CovidStatus,
      CountrySummaryResponse,
      Country,
      CountrySummaryInfo,
    } from './covid/index';
    
    // utils
    function $(selector: string) {
      return document.querySelector(selector);
    }
    function getUnixTimestamp(date: Date | string) {
      return new Date(date).getTime();
    }
    
    // DOM
    const confirmedTotal = $('.confirmed-total') as HTMLSpanElement;
    const deathsTotal = $('.deaths') as HTMLParagraphElement;
    const recoveredTotal = $('.recovered') as HTMLParagraphElement;
    const lastUpdatedTime = $('.last-updated-time') as HTMLParagraphElement;
    const rankList = $('.rank-list') as HTMLOListElement;
    const deathsList = $('.deaths-list') as HTMLOListElement;
    const recoveredList = $('.recovered-list') as HTMLOListElement;
    const deathSpinner = createSpinnerElement('deaths-spinner');
    const recoveredSpinner = createSpinnerElement('recovered-spinner');
    
    function createSpinnerElement(id: string) {
      const wrapperDiv = document.createElement('div');
      wrapperDiv.setAttribute('id', id);
      wrapperDiv.setAttribute(
        'class',
        'spinner-wrapper flex justify-center align-center'
      );
      const spinnerDiv = document.createElement('div');
      spinnerDiv.setAttribute('class', 'ripple-spinner');
      spinnerDiv.appendChild(document.createElement('div'));
      spinnerDiv.appendChild(document.createElement('div'));
      wrapperDiv.appendChild(spinnerDiv);
      return wrapperDiv;
    }
    
    // state
    let isDeathLoading = false;
    
    // api
    function fetchCovidSummary(): Promise<AxiosResponse<CovidSummaryResponse>> {
      const url = 'https://api.covid19api.com/summary';
      return axios.get(url);
    }
    
    function fetchCountryInfo(
      countryName: string,
      status: CovidStatus
    ): Promise<AxiosResponse<CountrySummaryResponse>> {
      // status: confirmed, recovered, deaths
      const url = `https://api.covid19api.com/country/${countryName}/status/${status}`;
      return axios.get(url);
    }
    
    // methods
    function startApp() {
      setupData();
      initEvents();
    }
    
    // events
    function initEvents() {
      rankList.addEventListener('click', handleListClick);
    }
    
    async function handleListClick(event: MouseEvent) {
      let selectedId = '';
      if (
        event.target instanceof HTMLParagraphElement ||
        event.target instanceof HTMLSpanElement
      ) {
        selectedId = event.target.parentElement?.id;
      }
      if (event.target instanceof HTMLLIElement) {
        selectedId = event.target.id;
      }
      if (isDeathLoading) {
        return;
      }
      clearDeathList();
      clearRecoveredList();
      startLoadingAnimation();
      isDeathLoading = true;
      const { data: deathResponse } = await fetchCountryInfo(
        selectedId,
        CovidStatus.Deaths
      );
      const { data: recoveredResponse } = await fetchCountryInfo(
        selectedId,
        CovidStatus.Recovered
      );
      const { data: confirmedResponse } = await fetchCountryInfo(
        selectedId,
        CovidStatus.Confirmed
      );
      endLoadingAnimation();
      setDeathsList(deathResponse);
      setTotalDeathsByCountry(deathResponse);
      setRecoveredList(recoveredResponse);
      setTotalRecoveredByCountry(recoveredResponse);
      setChartData(confirmedResponse);
      isDeathLoading = false;
    }
    
    function setDeathsList(data: CountrySummaryResponse) {
      const sorted = data.sort(
        (a: CountrySummaryInfo, b: CountrySummaryInfo) =>
          getUnixTimestamp(b.Date) - getUnixTimestamp(a.Date)
      );
      sorted.forEach((value: CountrySummaryInfo) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item-b flex align-center');
        const span = document.createElement('span');
        span.textContent = value.Cases.toString();
        span.setAttribute('class', 'deaths');
        const p = document.createElement('p');
        p.textContent = new Date(value.Date).toLocaleDateString().slice(0, -1);
        li.appendChild(span);
        li.appendChild(p);
        deathsList.appendChild(li);
      });
    }
    
    function clearDeathList() {
      deathsList.innerHTML = '';
    }
    
    function setTotalDeathsByCountry(data: CountrySummaryResponse) {
      deathsTotal.innerText = data[0].Cases.toString();
    }
    
    function setRecoveredList(data: CountrySummaryResponse) {
      const sorted = data.sort(
        (a: CountrySummaryInfo, b: CountrySummaryInfo) =>
          getUnixTimestamp(b.Date) - getUnixTimestamp(a.Date)
      );
      sorted.forEach((value: CountrySummaryInfo) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item-b flex align-center');
        const span = document.createElement('span');
        span.textContent = value.Cases.toString();
        span.setAttribute('class', 'recovered');
        const p = document.createElement('p');
        p.textContent = new Date(value.Date).toLocaleDateString().slice(0, -1);
        li.appendChild(span);
        li.appendChild(p);
        recoveredList.appendChild(li);
      });
    }
    
    function clearRecoveredList() {
      recoveredList.innerHTML = '';
    }
    
    function setTotalRecoveredByCountry(data: CountrySummaryResponse) {
      recoveredTotal.innerText = data[0].Cases.toString();
    }
    
    function startLoadingAnimation() {
      deathsList.appendChild(deathSpinner);
      recoveredList.appendChild(recoveredSpinner);
    }
    
    function endLoadingAnimation() {
      deathsList.removeChild(deathSpinner);
      recoveredList.removeChild(recoveredSpinner);
    }
    
    async function setupData() {
      const { data } = await fetchCovidSummary();
      setTotalConfirmedNumber(data);
      setTotalDeathsByWorld(data);
      setTotalRecoveredByWorld(data);
      setCountryRanksByConfirmedCases(data);
      setLastUpdatedTimestamp(data);
    }
    
    function renderChart(data: number[], labels: string[]) {
      const lineChart = $('#lineChart') as HTMLCanvasElement;
      const ctx = lineChart.getContext('2d');
      Chart.defaults.color = '#f5eaea';
      Chart.defaults.font.family = 'Exo 2';
      new Chart(ctx, {
        type: 'line',
        data: {
          labels,
          datasets: [
            {
              label: 'Confirmed for the last two weeks',
              backgroundColor: '#feb72b',
              borderColor: '#feb72b',
              data,
            },
          ],
        },
        options: {},
      });
    }
    
    function setChartData(data: CountrySummaryResponse) {
      const chartData = data
        .slice(-14)
        .map((value: CountrySummaryInfo) => value.Cases);
    
      const chartLabel = data
        .slice(-14)
        .map((value: CountrySummaryInfo) =>
          new Date(value.Date).toLocaleDateString().slice(5, -1)
        );
      renderChart(chartData, chartLabel);
    }
    
    function setTotalConfirmedNumber(data: CovidSummaryResponse) {
      confirmedTotal.innerText = data.Countries.reduce(
        (total: number, current: Country) => (total += current.TotalConfirmed),
        0
      ).toString();
    }
    
    function setTotalDeathsByWorld(data: CovidSummaryResponse) {
      deathsTotal.innerText = data.Countries.reduce(
        (total: number, current: Country) => (total += current.TotalDeaths),
        0
      ).toString();
    }
    
    function setTotalRecoveredByWorld(data: CovidSummaryResponse) {
      recoveredTotal.innerText = data.Countries.reduce(
        (total: number, current: Country) => (total += current.TotalRecovered),
        0
      ).toString();
    }
    
    function setCountryRanksByConfirmedCases(data: CovidSummaryResponse) {
      const sorted = data.Countries.sort(
        (a: Country, b: Country) => b.TotalConfirmed - a.TotalConfirmed
      );
      sorted.forEach((value: Country) => {
        const li = document.createElement('li');
        li.setAttribute('class', 'list-item flex align-center');
        li.setAttribute('id', value.Slug);
        const span = document.createElement('span');
        span.textContent = value.TotalConfirmed.toString();
        span.setAttribute('class', 'cases');
        const p = document.createElement('p');
        p.setAttribute('class', 'country');
        p.textContent = value.Country;
        li.appendChild(span);
        li.appendChild(p);
        rankList.appendChild(li);
      });
    }
    
    function setLastUpdatedTimestamp(data: CovidSummaryResponse) {
      lastUpdatedTime.innerText = new Date(data.Date).toLocaleString();
    }
    
    startApp();
profile
Move fast & break things

0개의 댓글