개인 공부를 하던 와중에 친구와 공부내기에서 떠올린 프로젝트이다.
친구와 몇시간 혹은 특정 장소에서 공부한걸 인증한걸 공유하자 (도서관, 카페) 대신 집과 거리가 멀고, 공부를 하지 않고 인증만해도 그정도의 정성은 인정하자는 분위기였다.
근데 매번 타이머키고 인증하고, 또 공부 타이머앱 깔고 분석하기엔 뭔가 별루였다… (뭔가 보상이 없달까?)
그래서 뭔가 보상도 있고, 인터페이스도 쉬우면서, 동기부여가 되는 타이머앱을 만들기로 했다.
- 기본기능
- 타이머 : 당연하다, 타이머 앱이니까 타이머는 기본 탑재이다
- 분석기능 : 기본적인 목표치를 설정 주단위 분석 또는 달단위 분석 기능을 탑재할까 싶다
- 공유기능 : 자신의 공부시간 혹은 공부량등을 자랑할수있게 공유기능을 넣을예정
- 커뮤니티 기능 : 사실 넣을까 말까 했지만 가장 중요하지 않을까 싶다. 혼자 공부하기보다 누군가의 도움 혹은 머리식힐겸의 커뮤니티 기능이 있으면 좋지 않을까? (카테고리별 커뮤니티)
- 심화기능
- 챌린지 : 상대방과 겨루기 기능으로 동기부여가 되지 않을까? (win - lose)
- 보상기능 : 아직 생각중이긴하나 캐릭터같은것을 성장시키는 느낌처럼 만들면 좋을거 같다 (게임?)
- 채팅 : 개인적으로 넣는다기보다 챌린지하는 상대와 대화기능이 있었으면 좋겠다는 느낌에 넣은거지만 만들다보면 채팅이 기본기능으로 탑재될 가능성도 있다.
우선순위
- 로그인
- 회원가입
- Room 기능
- Share_room (공유방) → challanges
- 타이머
- Single_room
- 타이머
- 회원로직
- 비회원로직
- 공유로직
- 스탑워치(기록x)
- 타이머
- Share_room (공유방) → challanges
- 타이머 관련기능
- 마이페이지
- 프로필 변경
- 타이머 기록
- 차트 및 측정 기능
- 분석기능
후순위
- 커뮤니티 기능
- 카테고리별 커뮤니티
- 타이머 종료 이후 winner, loser 기능
- 보상 기능
- 채팅 기능
- React (CRA) → vite
- tailwindCSS
- https://daisyui.com/ → 빠른 mvp 를 위한 작업
Recoil- zustand
- Firebase
- Jest/React-testing-library
- https://github.com/gpbl/react-day-picker
- https://github.com/wojtekmaj/react-calendar에 비해 업데이트 등의 장점이 있다고 생각
Nextjs로 구현할려다 현재 appDir emotion관련된 부분때문에 react로 먼저 구현이후 nextjs로 포팅할 예정이다.
현재 빠르게 구현을 위해 Firebase를 사용하지만, 추후 nestjs로 백엔드 개발과 DB도 만들어볼 예정이다.
무엇보다 이번 프로젝트는 유명한 tailwindCSS와 테스트코드도 작성될 예정
---
title: challenge_timer ERD
---
erDiagram
POST_TYPE {
string POST_TYPE_ID
string POST_TYPE
}
POST {
string POST_ID
string USER_ID
string POST_TYPE_ID
string POST_TITLE
string POST_DESCRIPTION
string POST_CONTENT
datetime CREATE_DATE
datetime UPDATE_DATE
}
USER {
string USER_ID
string USER_PW
string USER_NAME
string USER_NICKNAME
string USER_GOAL
string USER_CATEGORY
string USER_EXP
datetime CREATE_DATE
datetime UPDATE_DATE
}
CHALLENGE_ROOM {
string ROOM_ID
string ROOM_NAME
string ROOM_DESCRIPTION
boolean ROOM_FINISH
datetime CREATE_DATE
datetime UPDATE_DATE
datetime FINISH_TIME
}
CHALLENGE_ROOM_USER {
int ROOM_USER_ID
string ROOM_ID
string USER_ID
datetime ROOM_ENTER_TIME
datetime ROOM_EXIT_TIME
boolean ROOM_INSIDE
boolean ROOM_WINNER
}
TIMER {
string TIMER_ID
string USER_ID
datetime TIMER_START_TIME
datetime TIMER_END_TIME
datetime TIMER_REAL_END_TIME
datetime CREATE_DATE
datetime UPDATE_DATE
number percentTimesDay
number settingTime
number endTime
boolean finish
}
POST_TYPE ||--o{ POST : "linked to"
POST ||--o{ USER : "created by"
CHALLENGE_ROOM ||--o{ CHALLENGE_ROOM_USER : "has users"
USER ||--o{ CHALLENGE_ROOM_USER : "joins rooms"
USER ||--o{ TIMER : "sets timers"
sequenceDiagram
participant Member
participant NonMember
participant Timer
participant Stopwatch
participant Competition
participant Scoring
participant DB
Member ->> Timer: Start Timer
alt Time >= 80%
Timer ->> DB: Log Record
Member ->> Timer: Request Analysis
Timer ->> Scoring: Provide Analysis
else
Timer ->> DB: Log Invalid Record
end
NonMember ->> Timer: Start Timer
Timer ->> NonMember: Save Data to Local Storage
NonMember -->> Timer: No Analysis Access
Member ->> Stopwatch: Start Stopwatch
Stopwatch -->> Member: No Records Logged
Stopwatch -->> Member: Stop Time Ignored
Member ->> Competition: Connect to Opponent
Competition ->> Timer: Host Sets Time
alt Leave Before Time?
alt Time >= 80%
Timer ->> DB: Log Record
else
Timer ->> Competition: Apply Penalty (-5)
end
else
Timer ->> Competition: No Penalty
end
Timer ->> Competition: Minimize/Close?
alt Rejoin within 5 min
Competition ->> Timer: Apply Penalty (-5)
else
Timer ->> Competition: Opponent Wins
end
Timer ->> Scoring: Calculate Score
alt Time >= 80%
Scoring ->> Member: Winner +20 Points
Scoring ->> Member: Loser Points Based on %
else
Scoring ->> Member: No Score
end
Scoring ->> Member: Tie +5 Points Each
-
타이머
- 회원
- 타이머의 경우 설정된 시간에서 80% 이상할시에 기록으로 인정
- 그외 기록의 경우 로그에서 확인은 가능하지만 최종 기록으로는 인정하지 않음
- 분석기능을 통해 자신의 기록을 확인 가능
- 비회원
- 비회원의 경우 로컬스토리지에 저장된 데이터만 가져온다
- 분석 기능은 사용할수 없다.
- 회원
-
스탑워치
- 스탑워치의 경우 기록으로 인정 x (정확한 캐치가 불가능함)
- 스탑워치 정지시간은 기록되지 않는다 (측정당시에만 유효한 데이터)
-
상대방과의 경쟁 (타이머)
- 상대방과의 연결된 기준으로 설정되며, 기준시간의 경우 방장이 설정한 시간 기준으로 기록된다
- 기준시간보다 낮은 시간에 나간경우 타이머 기준에 따라 80% 이상일때만 기록
- 비회원의 경우 따로 기록하지 않는다
- 회원의 경우 DB에 로그기록
- 기준시간내에 사용자가 최소화, 닫기 등의 행동을 할경우
- 5분의 유효시간을 두고, 사용자가 재입장을 하지 않을경우 자동적으로 상대방 승리로 처리
- 5분이내로 입장할경우
- 패널티로 상대방보다 낮은 점수로 기록됨 (-5)
- 기준시간보다 낮은 시간에 나간경우 타이머 기준에 따라 80% 이상일때만 기록
- 상대방과의 연결된 기준으로 설정되며, 기준시간의 경우 방장이 설정한 시간 기준으로 기록된다
-
점수기준
- 점수기준은 기준시간을 %(퍼센티지)로 측정했을시 기준으로 처리하며, 기준시간을 모두 채울시 100점, 그외 시간에 나갈시 관련 % 점수로 처리된다 ex) 80% → 80점, 100% → 100점, 79% → 점수 없음
- 단, 80% 미만일 경우 측정 및 기록을 하지 않으며, 점수또한 측정되지 않는다.
- 패널티로 80% 미만으로 측정된 경우도 포함된다
- 경쟁 승자 점수
- 승자의 경우 기준점수 (최소:80, 최대:100) + 20점을 추가로 받는다
- 패자의 경우 80% 이상일 경우 관련 점수에 따라 분배되며 추가 점수는 없다
- 동률일 경우 모두 기준점수에 따라 분배되며 + 5점을 추가로 받는다.