-
Notifications
You must be signed in to change notification settings - Fork 29
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Mission5/정동환] Project_Notion_VanillaJs 과제 #43
Open
DongjaJ
wants to merge
59
commits into
4/#5_DongjaJ
Choose a base branch
from
4/#5_DongjaJ_working
base: 4/#5_DongjaJ
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from 1 commit
Commits
Show all changes
59 commits
Select commit
Hold shift + click to select a range
3920438
:tada: Chore: project setting
DongjaJ 98fbf6a
:sparkles: Chore: Component 클래스
DongjaJ 60816b6
:art: Chore: 페이지 구조 세팅
DongjaJ 53ddc85
:sparkles: Chore: Store 클래스 생성
DongjaJ 08ab083
:sparkles: Feat: Router 기능 구현
DongjaJ 0645823
:sparkles: Feat: API 기능 구현
DongjaJ 1774b79
Update README.md
DongjaJ fca9e36
:hammer: Script: build script 변경
DongjaJ fbf9cfc
:hammer: Script: 오타 수정
DongjaJ cbab109
Update README.md
DongjaJ dc1fad5
Update README.md
DongjaJ 611f8ac
:sparkles: Feat: 작성한 글 자동으로 로컬 스토리지에 저장
DongjaJ 71c8414
:lipstick: Design: 전체 페이지 레이아웃 설정
DongjaJ a16034e
:sparkles: Feat: Store 설계 및 사이드바와 PostList Store 연결
DongjaJ 9577e4b
:sparkles: Feat: 사이드바에서 -버튼 누를시 삭제하는 기능 추가
DongjaJ 93062fb
:sparkles: Feat: 사이드바에서 문서 추가 및 삭제 구현
DongjaJ d5abd6c
:sparkles: Feat: 자동으로 서버에 저장 기능 추가
DongjaJ 3ca5a79
:sparkles: Feat: 로딩중에 로딩중 이라고 메시지 렌더링
DongjaJ 0386bae
:sparkles: Feat: 보고 있는 메모장 삭제시 홈으로 라우팅
DongjaJ 70e90cb
:lipstick: Design: 사이드바 제목 길어지면 말 줄임 표시
DongjaJ 9ae3dfa
:recycle: Refactor: 절대경로 안된 것들 적용
DongjaJ 8c38549
:lipstick: Design: 사이드바 게시글 토글 기능 구현
DongjaJ e6dfd7c
:sparkles: Feat: 사이드 바 클릭시 게시글로 라우팅
DongjaJ 0d8587f
:sparkles: Refactor: SideBar 이벤트리스너 함수 분리
DongjaJ a778d07
:sparkles: Feat: focus 된 post 하이라이트 처리
DongjaJ 3937f04
:bug: Fix: 자식 documents눌렀을 때 강조 안되는 것 수정
DongjaJ 14a9b2a
:lipstick: Design: Favicon, title 적용
DongjaJ 3e5081e
:sparkles: Feat: 게시글 추가, 삭제, 수정 알림기능
DongjaJ b60f130
:sparkles: Feat: 게시글 아래에 자식 문서들 렌더링
DongjaJ c8ed367
:lipstick: Design: grid로 전체 레이아웃 잡음
DongjaJ a0f650f
:sparkles: Feat: 자식 리스트 누르면 자식으로 이동
DongjaJ 7168fdc
:recycle: Refactor: PostList store action 이름 변경
DongjaJ 136e387
:pencil2: Fix: delete 알림 버그 수정
DongjaJ 90fb00d
:lipstick: Design: home page ui 기초 구현
DongjaJ c2f698e
:sparkles: Feat: Not Found 페이지 구현
DongjaJ 8901724
:sparkles: Feat: Home UI 수정
DongjaJ dbb9741
:sparkles: Feat: SideBar 로고 클릭시 홈으로 라우팅
DongjaJ b240061
:recycle: Refactor: footer component로 분리
DongjaJ 7e9cf82
:sparkles: Feat: content contentEditable로 리팩토링 하고 마지막 글자에 커서 가도록 수정
DongjaJ aedb496
:sparkles: Feat: PostEdit 페이지 브레드컴블 추가
DongjaJ 21a1ef7
:sparkles: Feat: contentEditable placeholder 넣음
DongjaJ 2308a84
:sparkles: Feat: underline, 취소선 기능
DongjaJ ea617cf
:sparkles: Feat: Editor굵기, 기울임, 밑줄, 취소선 기능 구현
DongjaJ 9074332
:sparkles: Feat: 가운데 정렬, 왼쪽 정렬, 오른쪽 정렬 구현
DongjaJ 47a0cdf
:bug: Fix: PostEdit 페이지 높이 계속 늘어나는 버그, 메모장 이외에 포커스해도 수정 버튼 클릭 이벤트 일어…
DongjaJ 5c53d32
:recycle: Refactor: 스타일 수정 함수 분리
DongjaJ af592e9
:sparkles: Feat: 여러 스타일을 순서에 상관없이 적용 및 제거 가능
DongjaJ fb982bd
:bug: Fix: 한 줄에서 부분적으로 스타일 적용후 해제 하면 텍스트 노드 분리 되는 문제 해결
DongjaJ 2d29435
:recycle: Feat: 왼쪽 정렬하면 span 없애도록 수정
DongjaJ 1c0d106
:sparkles: Feat: 이동한 페이지 까지 사이드바에서 드롭다운 열어서보여주는 기능
DongjaJ f9ab4c1
:bug: Fix: 사이드바에서 선택 한 페이지 까지 드롭다운 열리는 버그 수정
DongjaJ c98c104
:truck: Rename: 라우터 패스 변경
DongjaJ d443d63
Merge pull request #18 from DongjaJ/4/#5_DongjaJ_working
DongjaJ ee31d77
:bug: Fix: 홈으로 갔을 때 사이드바에 하이라이트 있는 버그 수정
DongjaJ d28f9ae
Delete: 빈 줄 제거
DongjaJ 3118a7f
:recycle: Refactor: 태그들 시맨틱하게 수정
DongjaJ ae5176a
:recycle: Refactor: 모달 클래스로 분리
DongjaJ 2e31f3c
:recycle: Refactor: debounce 함수 수정
DongjaJ 875a232
:recycle: Refactor: 게시글 페이지 브레드 크럼 에서 경로 찾는 기능 클래스로 분리
DongjaJ File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -19,8 +19,10 @@ export default class SideBar extends Component { | |
: `<h2>로딩중</h2>` | ||
} | ||
<footer class=${styles.footer} data-id=null> | ||
<i class="fa-solid fa-plus add"></i> | ||
<button class='add'> | ||
<i class="fa-solid fa-plus"></i> | ||
새로운 페이지 추가 | ||
</button> | ||
</footer>`; | ||
} | ||
|
||
|
@@ -65,58 +67,66 @@ export default class SideBar extends Component { | |
} | ||
|
||
setEvent() { | ||
this.$target.addEventListener('click', async ({ target }) => { | ||
const deleteButton = target?.closest('.delete'); | ||
|
||
if (!deleteButton) return; | ||
|
||
const deletedId = target.closest('li').dataset.id; | ||
await PostListStore.dispatch({ | ||
actionType: 'DELETE', | ||
payload: { id: deletedId }, | ||
}); | ||
const nowId = PostStore.getState()?.post?.id; | ||
if (parseInt(deletedId) === nowId) push('/'); | ||
this.addEvent({ | ||
eventType: 'click', | ||
selector: '.delete', | ||
callback: this.onClickDelete, | ||
}); | ||
|
||
this.$target.addEventListener('click', async ({ target }) => { | ||
const addButton = target?.closest('.add'); | ||
|
||
if (!addButton) return; | ||
|
||
const id = target.closest(`[data-id]`).dataset.id; | ||
await PostStore.dispatch({ | ||
actionType: 'CREATE_POST', | ||
payload: { parent: id }, | ||
}); | ||
await PostListStore.dispatch({ actionType: 'INIT' }); | ||
this.addEvent({ | ||
eventType: 'click', | ||
selector: '.add', | ||
callback: this.onClickAdd, | ||
}); | ||
|
||
this.$target.addEventListener('click', ({ target }) => { | ||
const dropDownButton = target?.closest(`.${styles.dropDown}`); | ||
|
||
if (!dropDownButton) return; | ||
this.addEvent({ | ||
eventType: 'click', | ||
selector: `.${styles.dropDown}`, | ||
callback: this.onClickToggle, | ||
}); | ||
|
||
const childList = dropDownButton | ||
.closest('li') | ||
.querySelector(`.${styles.childList}`); | ||
this.addEvent({ | ||
eventType: 'click', | ||
selector: `.${styles.title}`, | ||
callback: this.onClickLink, | ||
}); | ||
} | ||
|
||
if (!childList) return; | ||
async onClickDelete({ target }) { | ||
const deletedId = target.closest('[data-id]').dataset.id; | ||
await PostListStore.dispatch({ | ||
actionType: 'DELETE', | ||
payload: { id: deletedId }, | ||
}); | ||
const nowId = PostStore.getState()?.post?.id; | ||
if (parseInt(deletedId) === nowId) push('/'); | ||
} | ||
|
||
dropDownButton.classList.toggle(`${styles.down}`); | ||
childList.classList.toggle(`${styles.open}`); | ||
async onClickAdd({ target }) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 이런 event handler들은 저는 하나로 묶어서 관리합니다. const postHandler = {
async onClickDelete({ target }) {},
async onClickAdd({ target }) {},
onClickToggle({ target }) {},
onClickLink({ target }) {}
}
postHandler.onClickDelete(event);
postHandler.onClickAdd(event); |
||
const id = target.closest(`[data-id]`).dataset.id; | ||
await PostStore.dispatch({ | ||
actionType: 'CREATE_POST', | ||
payload: { parent: id }, | ||
}); | ||
await PostListStore.dispatch({ actionType: 'INIT' }); | ||
} | ||
|
||
this.$target.addEventListener('click', ({ target }) => { | ||
const title = target.closest(`.${styles.title}`); | ||
onClickToggle({ target }) { | ||
const dropDownButton = target.closest(`.${styles.dropDown}`); | ||
const childList = dropDownButton | ||
.closest('li') | ||
.querySelector(`.${styles.childList}`); | ||
|
||
if (!title) return; | ||
if (!childList) return; | ||
|
||
const { id } = title.closest('[data-id]').dataset; | ||
dropDownButton.classList.toggle(`${styles.down}`); | ||
childList.classList.toggle(`${styles.open}`); | ||
} | ||
|
||
console.log(id); | ||
onClickLink({ target }) { | ||
const title = target.closest(`.${styles.title}`); | ||
const { id } = title.closest('[data-id]').dataset; | ||
|
||
push(`/posts/${id}`); | ||
}); | ||
push(`/posts/${id}`); | ||
} | ||
} |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
p5 : 크.. 역시 함수 분리 장인👍