### 1. 진입 #### 첫 화면은 가계부 목록 - 로그인 여부 판단 - 되어있으면 가계부 목록 - 안되어 있으면 로그인 페이지 <br> ### 2. 가계부 목록 - READ - `GET /accountbook` | request | response | | -------- | -------- | | | statuscode, [{_id, name, description}...] | - 이 때 accountbook 안에 transaction들도 모두 가지고 올 것인가? - 만약 트랜잭션이 엄청 많다면 모든 transaction들을 가지고 있는 것이 성능 문제가 있을 것 같다. - {_id, name, description}만 가져오고 accountbook 목록은 useState로 관리한다. - accoutbook 전체를 가지고 있는 store를 만들것인가? - 굳이 필요가 없을 것 같다. - 우리의 UI 상에서는 가계부 선택으로 돌아가서 가계부를 선택했을 때 상태가 유지될 필요가 없을 것 같다. - CREATE - `POST /accountbook` | request | response | | -------- | -------- | | name, description | statuscode, _id, name, description | - UPDATE - `Patch /accountbook/:accountbookid` | request | response | | -------- | -------- | | name, description | statuscode, _id, name, description | - DELETE - `DELETE /accountbook/:accountbookid` | request | response | | -------- | -------- | | | statuscode | ### 3. 가계부 내역 - READ - `GET /accountbook/:accountbookid` | request | response | | -------- | -------- | | | statuscode, {_id, name, description, category, user, payment, transaction} | - 특정 어카운트북의 정보를 전부 store 데이터에 넣어서 전역으로 관리한다. 즉 어카운트북 안의 모든 페이지가 이 스토어를 참조한다. - 여기서 달력과 차트는 store에 있는 값을 직접 변경하지 않고 참조만 하기 때문에 특별히 API가 필요하지 않다. - CREATE - `POST /accountbook/:accountbookid/transaction` | request | response | | -------- | -------- | | content(내용), type(수입/지출), category({name, type, icon}), cost, date, payment({name, descriptioni})| statuscode, {_id, name, description, category, user, payment, transaction} | 1. db.accountBookModel.find({_id}) 2. accountBook.transactions 3. REQ => transaction 만들 4. accountBookModel.update({_id}, {transactions : [ ...accountBook.transactions , transaction ]}) - UPDATE - `PATCH /accountbook/:accountbookid/transaction/:transactionid` | request | response | | -------- | -------- | | content(내용), type(수입/지출), category({name, type, icon}), cost, date, payment({name, descriptioni})| statuscode | - mongoose에서 update를 할 때 return 값이 전체 data가 나오지 않기 때문에 응답코드만 주는 것이 편할 것 같다. - DELETE - `DELETE /accountbook/:accountbookid/transaction/:transactionid` | request | response | | -------- | -------- | | | statuscode | ### 4. 결제 수단 관리 - READ - accountbook 전체를 가져올 때 embeded 돼서 나오기 때문에 가계부의 결제수단만 가져오는 api는 필요가 없다. - CREATE - `POST /accountbook/:accountbookid/payment` | request | response | | -------- | -------- | | name, color, desc | statuscode, _id, name, description, color | - UPDATE - `UPDATE /accountbook/:accountbookid/payment/:paymentid` | request | response | | -------- | -------- | | name, color, desc | statuscode | - DELETE - `DELETE /accountbook/:accountbookid/payment/:paymentid` ### 카테고리 - CREATE - `GET /accountbook/:accountbookid/category` | request | response | | -------- | -------- | | name, type(수입/지출), icon | statuscode, _id, name, type, icon | - UPDATE - `PATCH /accoutbook/:acccountbookid/category/:categoryid` | request | response | | -------- | -------- | | name, type, icon | statuscode | - DELETE - `DELETE /accoutbook/:acccountbookid/category/:categoryid` | request | response | | -------- | -------- | | | statuscode |