Skip to content
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

[Feature/#18] : 타임테이블 수정 #19

Merged
merged 5 commits into from
Jan 14, 2025

Conversation

gaeulzzang
Copy link
Contributor

@gaeulzzang gaeulzzang commented Jan 9, 2025

✅ 𝗖𝗵𝗲𝗰𝗸-𝗟𝗶𝘀𝘁

  • merge할 브랜치의 위치를 확인해 주세요.(main❌/develop⭕)
  • 리뷰가 필요한 경우 리뷰어를 지정해 주세요.
  • 리뷰는 PR이 올라오면 최대한 빠르게 진행합니다.
  • P1 단계의 리뷰는 빠르게 확인 후 반영합니다.
  • Approve된 PR은 assigner가 머지하고, 수정 요청이 온 경우 수정 후 다시 push를 합니다.

📌 𝗜𝘀𝘀𝘂𝗲𝘀

📎 𝗪𝗼𝗿𝗸 𝗗𝗲𝘀𝗰𝗿𝗶𝗽𝘁𝗶𝗼𝗻

  • 시간 행 박스 크기 고정

    LazyVerticalGrid -> LazyColumn으로 수정

  • border 겹치면서 두께 두꺼워지는 문제 해결

    box border 없애고 drawBehind로 수정

  • 시간 행 제외한 헤더 부분은 n분의 1로 자동 크기 조정

    modifier weight(1f)로 문제 해결

  • 서버 api 명세서 참고하면서 엔티티 수정
  • 타임테이블 관련 로직 core/util에 있는 TimeTable.kt에 작성

📷 𝗦𝗰𝗿𝗲𝗲𝗻𝘀𝗵𝗼𝘁

💬 𝗧𝗼 𝗥𝗲𝘃𝗶𝗲𝘄𝗲𝗿𝘀

진짜 너무 어려워서 눈물 나왔어요.. 타임테이블로 트슛 쓸거임 ssibal
(구라 안치고 독감 더 심해지는 느낌 머리도 아프고 정신도 아프고 하.................. 토나와)

🚨 아래 내용 꼭 읽고 코리 달아주세요 ㅠㅠ 🚨
일단 앱바나 나머지 UI 요소들은 스크롤 안되고 고정입니다. 캘린더 내부에서 스크롤 한다고 하니까 참고해주세요.
캘린더 영역은 항상 RoundedCornerShape(8.dp)로 보여야 한다고 합니다. 아래 사진과 같이 피그마에서는 스크롤되는 캘린더일 때 양옆이 일직선으로 그려져 있던데 제가 구현한 방식이 맞는거라고 서희 언니한테 확인 받았습니다. 타임테이블에서 더이상 구현하지 못한 UI 디테일은 없는 것 같습니다.
image


스트링 추출하면 함수 이해하는게 더 어려울 것 같아서 스트링 추출 안하겠습니다.

@gaeulzzang gaeulzzang added ⭐ [FEAT] 새로운 기능 구현 🔨 [FIX] 버그 및 오류 발생 및 해결 🍂 가을 가응가 labels Jan 9, 2025
@gaeulzzang gaeulzzang self-assigned this Jan 9, 2025
@gaeulzzang gaeulzzang requested a review from a team as a code owner January 9, 2025 18:22
val selectedCells = remember { mutableStateListOf<Pair<Int, Int>>() } // Row, Column 저장
val days = availablePeriods.dates.size
val timeSlots =
TimeTable().calculateTimeSlots(availablePeriods.startTime, availablePeriods.endTime)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

P3 : TimeTable()을 여러번 사용하고있는것같은데 한번 생성하고 재사용하는건 별로일까용?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

와 여기 계산 머에요 . .?

Copy link
Contributor

@twogarlic twogarlic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

독감 걸려서 힘드셧을텐데 고생 많으셧슴니도

Comment on lines +99 to +120
.drawBehind {
val borderWidth = 1.dp.toPx()
val borderColor = Gray200

if (rowIndex > 0) {
drawLine(
color = borderColor,
start = Offset(0f, 0f),
end = Offset(size.width, 0f),
strokeWidth = borderWidth
)
}

if (columnIndex > 0) {
drawLine(
color = borderColor,
start = Offset(0f, 0f),
end = Offset(0f, size.height),
strokeWidth = borderWidth
)
}
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

P3: 오 이렇게 Box의 배경 레이어에 직접 테두리를 그리면 불필요한 중복을 제거할 수 있군요? 배워갑니다!

Comment on lines +73 to 94
Box(
modifier = when (cellType) {
CellType.Blank ->
Modifier
.width(42.dp)
.height(36.dp)

NoostakEditableTimeTableBox(
index = index,
days = days,
timeSlots = timeSlots,
backgroundColor = backgroundColor,
text = text,
onClick = {
if (cellType == CellType.Data) {
val cell = rowIndex to columnIndex
if (selectedCells.contains(cell)) {
selectedCells.remove(cell)
} else {
selectedCells.add(cell)
CellType.TimeHeader ->
Modifier
.width(42.dp)
.height(32.dp)

CellType.DateHeader ->
Modifier
.weight(1f)
.height(36.dp)

else ->
Modifier
.weight(1f)
.height(32.dp)
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

P3: 요렇게 크기 고정하셨군요! 👍👍

Comment on lines +24 to +29
fun determineCellType(rowIndex: Int, columnIndex: Int): CellType = when {
rowIndex == 0 && columnIndex == 0 -> CellType.Blank
rowIndex == 0 -> CellType.DateHeader
columnIndex == 0 -> CellType.TimeHeader
else -> CellType.Data
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

P3: 오 어떻게 셀을 구분하나 궁금했었는ㄷㅔ 간단하네요!!

Comment on lines +78 to +87
@Composable
fun getColorByLevel(level: Int): Color =
when (AvailabilityLevel.entries.firstOrNull { level in it.range }) {
AvailabilityLevel.NONE -> Color.Transparent
AvailabilityLevel.FEW -> NoostakTheme.colors.blue50
AvailabilityLevel.SOME -> NoostakTheme.colors.blue200
AvailabilityLevel.MANY -> NoostakTheme.colors.blue400
AvailabilityLevel.MOST -> NoostakTheme.colors.blue700
else -> NoostakTheme.colors.blue800
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

P3: 깔끔하고 너무 좋습니다ㅏㅏㅏ

Comment on lines +40 to +65
CellType.Blank, CellType.DateHeader, CellType.TimeHeader -> Color.Transparent
CellType.Data -> {
val startHour = extractHour(extractTime(availablePeriods.startTime))
val currentHour = startHour + (rowIndex - 1)

val date =
availablePeriods.dates.getOrNull(columnIndex - 1) ?: return Color.Transparent
// 해당 열(columnIndex) 날짜 데이터 가져오기
val formattedDate = extractDate(date)
val availableTimesForDate = availableTimes.members.flatMap { member ->
member.times.filter { extractDate(it.date) == formattedDate }
}

// 현재 시간에 해당하는 가능 레벨 계산
val totalMembers = availableTimes.members.size
val availableMembers = availableTimesForDate.count { availableTime ->
availableTime.times.any { timeEntity ->
val entityStartHour = extractHour(extractTime(timeEntity.memberStartTime))
val entityEndHour = extractHour(extractTime(timeEntity.memberEndTime))
currentHour in entityStartHour until entityEndHour
}
}
val percentage =
if (totalMembers == 0) 0 else (availableMembers * 100 / totalMembers)
getColorByLevel(percentage)
}
Copy link
Contributor

@youjin09222 youjin09222 Jan 13, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

P3: 와 이거 계산 어케하셨어요? 완전 천재자나😲

Comment on lines +112 to +134
fun getSelectedTimes(
selectedCells: List<Pair<Int, Int>>,
availablePeriods: PeriodEntity
): List<AvailableTimeEntity> {
val selectedTimes = mutableListOf<AvailableTimeEntity>()
val selectedCellsByDate = selectedCells.groupBy { it.second }
selectedCellsByDate.forEach { (dateColumnIndex, cells) ->
val date = availablePeriods.dates.getOrNull(dateColumnIndex - 1) ?: return@forEach
val times = cells.map { (rowIndex, _) ->
val startHour = extractHour(extractTime(availablePeriods.startTime)) + (rowIndex - 1)
val endHour = startHour + 1
TimeEntity(
memberStartTime = "${extractDate(date)}T${String.format("%02d", startHour)}:00:00",
memberEndTime = "${extractDate(date)}T${String.format("%02d", endHour)}:00:00"
)
}
if (times.isNotEmpty()) {
selectedTimes.add(AvailableTimeEntity(date = date, times = times))
}
}

return selectedTimes
}
Copy link
Contributor

@youjin09222 youjin09222 Jan 13, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

P3: 와 이거 진심 대단한데요..? (진심 어케함..)

Copy link
Contributor

@youjin09222 youjin09222 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

넘넘 고생 많으셨습니다! 코드 이해하느라 코리가 늦어진 점 너무 죄송해요...
저라면 아직도 오열하며 붙잡고 있을 것 같은데, 아프신 와중에도 너무 멋지게 구현하셔서 대단하다는 생각 뿐입니다..

Copy link
Member

@Eonji-sw Eonji-sw left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM! 엄청 복잡하고 빡셌을 텐데 잘하셨어요!!!
로직이 복잡해서 리팩은 나중에 천천히 해도 될 것 같네욤 ㅜ

@gaeulzzang gaeulzzang merged commit 3d0f132 into develop Jan 14, 2025
1 check passed
@gaeulzzang gaeulzzang deleted the feature/#18-timetable-fix branch January 22, 2025 06:55
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🍂 가을 가응가 ⭐ [FEAT] 새로운 기능 구현 🔨 [FIX] 버그 및 오류 발생 및 해결
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[FIX] : 타임테이블 border 이슈 고치기
4 participants