Skip to content

Todotodot/todotodot-extension

Repository files navigation

☑️ TODOTODOT

나만의 TODOTODOT 만들러 가기

☑️ TODOTODOT 이란?

TODOTODOT(투둣투둣)은 일반적인 Todo 어플리케이션에 게임의 요소를 가미한 웹 어플리케이션입니다.

평소 우리는 Todo 어플리케이션을 다운받으면 짧으면 3일, 길면 일주일 정도만 쓰고 다운받았던 사실조차 잊어버립니다. 그래서 Todo 어플리케이션을 어떻게 하면 유저가 오랫동안 재밌게 사용할 수 있을지에 대한 고민을 해보았습니다. Todo 플랫폼에 미니 게임을 넣으면 어떨까하는 생각이 제일 먼저 들었고, 그 게임을 혼자 아닌 여러 유저들이 참여하게 하면 우리만의 Todo 어플리케이션을 만들 수 있을 것 같다는 생각을 했습니다.

TODOTODOT의 핵심 기능은 유저가 Todo를 완료하고 싶으면 게임에 참여하여 승리해야만 완료할 수 있는 플랫폼을 가지고 있습니다. 만약 게임에 패배하면 Todo를 완료하지 못하고 다시 게임에 참여할 수 있습니다. 게임은 Todo 어플리케이션이라는 점을 염두에 두고 간단한 게임(Clicker Game)으로 구성하였습니다. 그룹의 경우 모든 인원이 참여해야만 게임을 시작할 수 있다는 조건을 추가하여 난이도 조절을 하였습니다.

그렇다면 이제 저희 TODOTODOT에 한번 참여해보세요!

☑️ 실행 방법

원격 저장소 내려받는 법

git clone https://github.com/Todotodot/todotodot-extension.git
npm install

환경 변수 설정법

SECRET_KEY=<YOUR_SECRET_KEY>
PORT=<YOUR_PORT>
NODE_ENV=<YOUR_ENVIRONMENT>

SECRET_KEY는 로그인의 인증을위해 서버와 주고받는 Json Web Token입니다. 서버의 EXTENSION_KEY와 SECRET_KEY를 통해 만들어졌습니다. 해당 키는 부족하다고 판단한 Google로그인이후 Server와 통신을 보다 안전하게 하기 위함입니다. 로컬 환경에서의 프로젝트 체험을 위해 해당 키는 공개되어있지만, 배포된 버전의 경우 다른 KEY를 사용하기 때문에 안심하셔도 됩니다.

실행법

  1. .env파일 생성 후 환경변수를 입력해줍니다
  2. 터미널에서 npm run build
  3. 이후 생성된 dist폴더를 확인하고
  4. Chrome 브라우저를 실행하고 chrome://extensions/에 접속
  5. 우측 상단의 Developer mode를 켜고
  6. 생성되는 Load unpacked버튼을 눌러 아까 만들어진 dist폴더를 선택해줍니다
  7. 생성된 익스텐션의 고유 ID를 기억해둡니다
  8. https://console.cloud.google.com/apis로 접속하여 사용자 인증 정보 -> + 사용자 인증 정보 만들기 -> OAuth 클라이언트 ID순으로 접속합니다
  9. 애플리케이션 유형에 Chrome 앱을 애플리케이션ID에 아까 생성된 익스텐션 ID를 입력합니다
  10. 생성되는 클라이언트 IDmanifest.json파일의 oauth2의 client_id에 입력해줍니다.
  11. 다시 구글 클라우드 콘솔로 돌아가OAuth 동의 화면을 클릭하고 테스트 사용자항목에 사용할 google 계정을 입력합니다.
  12. 이후 변경된 manifest.json파일을 적용하기위해 터미널로 돌아가 npm run build로 새로운 dist폴더를 만들어주고 chrome://extensions/에 접속후 우리 확장 프로그램의 새로고침 버튼을 클릭해줍니다.
  13. Server측 터미널에서 npm run dev로 서버를 작동시킵니다
  14. Chrome 브라우저의 프로필버튼을 클릭하고 로그인 후 브라우저와 계정의 sync를 켜주면 사용할 수 있습니다

테스트

npm test

☑️ 개발 기간

2022년 5월 30일 ~ 2022년 6월 17일

상세 일정

  • Week 1 - 기획 및 설계

    • 아이디어 검토 및 기술 검증
    • Figma 및 Lucid chart 작성
    • Flow chart 작성
    • 칸반 작업
    • Initial set up
  • Week 2 - 기능 개발

    • 크롬 익스텐션 로그인 구현
  • Week 3 - 기능 개발 및 배포

    • 크롬 익스텐션 CRUD 구현
    • 배포 (Netlify, AWS)
    • 테스트 코드 작성

⚙️ Tech stack

Extension : React Styled-components axios webpack

📌 Features

Page Features Description
Main Login Google OAuth 2.0을 사용하여 로그인합니다.
Profile Personal Todo와 Group List를 오갈 수 있는 버튼이 있습니다.
Personal Todo 유저의 개인 TodoList가 보여지며 Todo의 생성/수정/삭제가 가능합니다.
Todo의 체크박스를 클릭 시 게임화면으로 이동합니다.
Group List 유저가 속한 그룹 리스트가 보여지며, 그룹의 생성/수정/삭제가 가능합니다.
그룹을 클릭 시 그룹 내의 Todo List 페이지로 이동합니다.
Group Todo List 해당 그룹의 TodoList가 보여지며, Todo의 생성/수정/삭제가 가능합니다.
Todo의 체크박스를 클릭 시 그룹 게임화면으로 이동합니다.

🧠 회고

강원희

  • 항상 사용하는 웹 브라우저인 크롬에서 확장 프로그램은 떼려야 뗄 수 없는 부분이라고 생각합니다. 특히 Redux DevToolsJSON Viewer가 친숙한 저에겐 더욱 익숙하게 다가왔습니다. 그러던 중 Todotodot 프로젝트에 Chrome Extension을 적용해보면 어떨까? 라고 생각했고 더 나아가서 ReactCreate-React-App없이 직접 Webpack설정을 통해 만들어보자란 생각까지 가게 되었습니다. 웹팩이 익숙지 않아 번들링되는 파일들의 경로 설정과 Extension 로그인 구현에 시간이 굉장히 오래 걸렸습니다. Chrome Extension의 뼈대를 구성하고 정의하는 manifest의 버전이 v2에서 v3으로 올라오면서 firebase를 이용하는 Google 로그인을 사용할 수 없어 chrome.identity API를 사용해 해결하는 데까지 오랜 시간이 걸렸고, 로그인 이후에도 사용자에 대한 인증이 부족하다고 판단해 팀원과의 회의 끝에 Extension과 Server가 고유한 Token을 소유하고 요청과 응답 간에 해당 Token의 진위를 확인한다면 조금은 더 안전하리라 판단하고 구현했습니다. 흔치 않은 작업이라 얻을 수 있는 정보가 적어서 힘들었지만 혼자라면 생각하지 못했을 부분들을 팀원들이 뒤에서 제시해주고(Token사용), 또 놓치고 있는 예외의 경우(Extension로그인시 생기는 서버측 에러 등)를 짚어주어 많은 도움이 됐습니다.

  • 이번 프로젝트를 통해 또한 **"개발자로서의 협업이란 이런 것이구나"**라고 처음 느낄 수 있었습니다. 코드 한 줄에도 모든 사람의 의견이 들어있다는 것, 그 의견이 서로 다를 때 소통하고 합의점을 찾는 방법, 합의를 통해 우리 팀만의 고유 코드 스타일을 정하고 일관된 코드를 작성하는 방법, 또한 책임과 의무를 다하는 당연하지만 가장 중요한 태도에 대해 느끼고 되새기게 되는 값진 경험이었습니다.

공지현

  • 팀 프로젝트를 마무리하며 회고를 해보자면, 가장 많이 노력했던 부분은 팀원들간 의사소통 부분입니다.

    팀원들과 회의를 할 때면 서로 다른 주제를 이야기할 떄도 있었고 의견 충돌이 있을 때도 있었습니다. 이런 이슈가 발생할 때마다 더욱 팀원들의 목소리에 귀를 기울이려고 했습니다.

    한 예로 클라이언트에서 서버에 요청을 보내기 위해 uri를 사용하였는데, 팀원 중 저 포함 다른 분과 함께 왜인지 착각을 하여 두 개의 다른 요청임에도 불구하고 같은 uri를 작성했었습니다. 다행히 팀장님이 그 부분을 발견하여 수정할 것을 요쳥했지만, 저와 다른 팀원은 다른 요청에는 uri가 달라야한다는 것을 파악하지 못하고 문제가 없을 것이라 주장했었습니다. 이 과정에서 저희 팀은 의사소통에 문제를 겪었고 서로가 말하고자 하는 바를 이해하지 못했습니다. 하지만 여기서 누구하나 자신의 의견을 강하게 끌고가려는 팀원은 없었습니다. 각자의 논리를 바탕으로 왜 그렇게 생각하는지에 대해 집중했고 이야기를 나누다보니 저와 다른 팀원은 uri에 대한 개념을 잘못 인지하고 있음을 알아차리고 바로 피드백을 수용했습니다.

    이 과정은 팀 프로젝트를 진행하며 모든 의논사항이나 이슈가 있을 때에 똑같이 적용되었으며, 수 많은 상의를 거치며 팀원들간의 나름의 노하우도 생겼습니다. 상대방의 말하고자하는 바를 이해하지 못한다면 우선 정확히 어떤 부분에서 이해가 되지 않는지 본인의 충분한 설명이 필요했으며 상대방도 설명을 듣고 어떤 부분을 더 설명해주면 좋을지 고민해야했습니다. 초반에 의사소통을 매끄럽게 하기 위해 시간 투자를 많이 하였지만 결국 프로젝트 후반에는 이러한 과정이 시간을 아껴주었고 서로의 의견을 더욱 활발하게 교환할 수 있었습니다.

    팀 프로젝트를 진행하며 저희 팀의 가장 큰 장점이라고 생각하고 의사소통하는 부분에 있어서 최선을 다해준 팀원분들께 감사함을 느낍니다.

김다은

  • Character Animation

    게임 요소가 생기면서 가장 고민한 것 중 하나는 게임 캐릭터의 애니메이션이었습니다. 캐릭터 애니메이션은 ‘react-responsive-spritesheet’ 라이브러리를 사용했는데, 팀원들과의 논의 끝에 클리커 게임으로 게임의 장르가 정해졌고, 클리커라고 하면 캐릭터가 한 번의 애니메이션 작업을 실행하고 마치는 작업을 클릭을 할 때 마다가 되어야 한다고 생각했습니다. 그리고 애니메이션이 끝나면 다시 처음 프레임으 로 돌아가 실행하고, 원하는 프레임에서 자유롭게 멈출 수 있어야 된다는 기준에 걸맞다고 생각이 되어 ‘react-responsive-spritesheet’ 라이브러리를 사용하게 되었습니다.

  • 전역 상태 관리 라이브러리 사용 이유

    팀원들과의 회의를 통해 메인으로 사용될 컴포넌트들을 분리해 작업을 하게되었고, 나중에 각각의 컴포넌트들을 통합하는 작업을 진행을 하게 되었습니다. 통합과정을 진행하다보니, 유저와 모달, 그룹의 데이터를 필요한 컴포넌트에 전달하는 작업에 props를 사용하게되었고, 그 때문에 props를 전달받는 컴포넌트에 Proptypes를 일일히 설정을 하고보니 생각보다 컴포넌트 간의 데이터 전달이 많다는 것을 느끼게 되었습니다. 처음 기획할 때에는 페이지 간의 이동도 적고, 컴포넌트 간의 데이터 전달이 적을 것으로 생각해 게임 관련 외에는 전역 상태 관리 라이브러리를 사용하지 않아도 된다고 생각했지만, 위와 같은 상황과 더불어 state 값이 변화가 되었을 때 렌더링이 되지 않는 문제까지 겹쳐지면서 팀원들과 의논한 끝에 전역 상태 관리 라이브러리를 사용하기로 했습니다.

    팀 프로젝트를 진행하면서 아침마다 항상 되새기고 했던 것 중 하나가 팀원들과의 커뮤니케이션을 하면서 의견이 제대로 전달되지 않아 서로 다른 이야기를 하고 있을 때, 지레짐작으로 넘어가지 않고 제대로 이해를 하고 넘어갔는지를 파악하는 것이었습니다. 그래서 항상 다른 이야기를 하는 것 같다는 낌새가 보이면 그 때 회의를 멈추고 현재 각자 어떤 것을 이야기하고 있는지를 말하고 다른 이야기를 하고 있다면 지금 이 주제를 논의하고 있다고 말하고 이해가 안되면 이해가 될 때 까지 계속 말하면서 회의에 따라오지 못하는 분이 없도록 노력했습니다. 나중에는 저 뿐만이 아니라 다른 팀원 분들도 제가 못 따라온다던지 하면 바로 파악하고 이해하고 따라올 수 있도록 해주셨습니다.

    프로젝트를 진행하면서 피곤하고 지쳐서 포기하고 싶었던 순간이 여러번이었는데, 팀원들이 많이 다독여주었고 팀원들의 노력하는 모습을 보면서 그만큼 더 에너지를 얻어 피곤하더라도 포기하지 않고 계속 노력할 수 있었던 것 같습니다.

🐜 팀원 소개

공지현 강원희 김다은

About

Repository for chrome extension

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published