Skip to content

Commit

Permalink
refactor: survey 도메인의 위치를 root모듈로 변경한다
Browse files Browse the repository at this point in the history
  • Loading branch information
devxb committed Mar 8, 2024
1 parent 42f5f7f commit 3536b32
Show file tree
Hide file tree
Showing 25 changed files with 78 additions and 74 deletions.
12 changes: 12 additions & 0 deletions src/build.gradle
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
repositories {
mavenCentral()
}

dependencies {
implementation project(":core:data")
implementation project(":core:time")

implementation "org.springframework.boot:spring-boot-starter-data-jpa"

testRuntimeOnly "com.h2database:h2"
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.feedback
package domain.feedback

import me.nalab.core.time.TimeUtil
import java.time.Instant
Expand All @@ -8,7 +8,7 @@ import javax.persistence.Embeddable
@Embeddable
class Bookmark(
@Column(name = "is_bookmarked", nullable = false)
var isBookmarked: Boolean = BOOKMARK_DEFAULT_STATE,
var isBookmarked: Boolean = domain.feedback.Bookmark.Companion.BOOKMARK_DEFAULT_STATE,

@Column(name = "bookmarked_at", columnDefinition = "TIMESTAMP(6)", nullable = false)
var bookmarkedAt: Instant,
Expand All @@ -17,6 +17,7 @@ class Bookmark(
companion object {
private const val BOOKMARK_DEFAULT_STATE = false

fun impossible(): Bookmark = Bookmark(bookmarkedAt = TimeUtil.toInstant())
fun impossible(): domain.feedback.Bookmark =
domain.feedback.Bookmark(bookmarkedAt = TimeUtil.toInstant())
}
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.feedback
package domain.feedback

import javax.persistence.*

Expand All @@ -7,11 +7,11 @@ class ChoiceFormQuestionFeedback(
id: Long,
formQuestionId: Long,
isRead: Boolean = false,
bookmark: Bookmark = Bookmark.impossible(),
feedback: Feedback,
bookmark: domain.feedback.Bookmark = domain.feedback.Bookmark.Companion.impossible(),
feedback: domain.feedback.Feedback,

@ElementCollection
@Column(name = "selects")
@CollectionTable(name = "selects", joinColumns = [JoinColumn(name = "form_feedback_id")])
private val selectedChoiceIds: MutableSet<Long>,
) : FormQuestionFeedbackable(id, formQuestionId, isRead, bookmark, feedback)
) : domain.feedback.FormQuestionFeedbackable(id, formQuestionId, isRead, bookmark, feedback)
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.feedback
package domain.feedback

import me.nalab.core.data.common.TimeBaseEntity
import javax.persistence.*
Expand All @@ -18,17 +18,17 @@ class Feedback(
fetch = FetchType.LAZY,
cascade = [CascadeType.PERSIST, CascadeType.MERGE]
)
val questionFeedbacks: MutableList<FormQuestionFeedbackable> = mutableListOf(),
val questionFeedbacks: MutableList<domain.feedback.FormQuestionFeedbackable> = mutableListOf(),

@Column(name = "is_read", nullable = false)
private var isRead: Boolean = false,

@JoinColumn(name = "reviewer_id", nullable = false)
@OneToOne(fetch = FetchType.LAZY, cascade = [CascadeType.PERSIST, CascadeType.MERGE])
val reviewer: Reviewer,
) : Comparable<Feedback>, TimeBaseEntity() {
val reviewer: domain.feedback.Reviewer,
) : Comparable<domain.feedback.Feedback>, TimeBaseEntity() {

override fun compareTo(other: Feedback): Int {
override fun compareTo(other: domain.feedback.Feedback): Int {
if (updatedAt.isAfter(other.updatedAt)) {
return -1
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.feedback
package domain.feedback

import javax.persistence.*

Expand All @@ -17,9 +17,9 @@ abstract class FormQuestionFeedbackable(
open var isRead: Boolean = false,

@Embedded
open val bookmark: Bookmark,
open val bookmark: domain.feedback.Bookmark,

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "feedback_id")
val feedback: Feedback,
val feedback: domain.feedback.Feedback,
)
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package me.nalab.survey.domain.feedback
package domain.feedback

import me.nalab.core.data.common.TimeBaseEntity
import me.nalab.survey.domain.feedback.value.NickName
import domain.feedback.value.NickName
import javax.persistence.Column
import javax.persistence.Entity
import javax.persistence.Id
Expand All @@ -15,7 +15,7 @@ class Reviewer(
val id: Long,

@Column(name = "nick_name", nullable = false)
internal var nickName: NickName,
internal var nickName: domain.feedback.value.NickName,

@Column(name = "collaboration_experience", nullable = false)
val collaborationExperience: Boolean,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.feedback
package domain.feedback

import javax.persistence.*

Expand All @@ -7,11 +7,11 @@ class ShortFormQuestionFeedback(
id: Long,
formQuestionId: Long,
isRead: Boolean = false,
bookmark: Bookmark,
feedback: Feedback,
bookmark: domain.feedback.Bookmark,
feedback: domain.feedback.Feedback,

@ElementCollection
@CollectionTable(name = "reply", joinColumns = [JoinColumn(name = "form_feedback_id")])
@Column(name = "replies")
val replies: MutableList<String>,
) : FormQuestionFeedbackable(id, formQuestionId, isRead, bookmark, feedback)
) : domain.feedback.FormQuestionFeedbackable(id, formQuestionId, isRead, bookmark, feedback)
28 changes: 28 additions & 0 deletions src/main/kotlin/domain/feedback/value/NickName.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
package domain.feedback.value

import javax.persistence.Embeddable

@Embeddable
class NickName(
val value: String
) {

companion object {
private const val FIRST_NAME = "A"
fun firstNickName(): domain.feedback.value.NickName =
domain.feedback.value.NickName(domain.feedback.value.NickName.Companion.FIRST_NAME)

fun nextNickName(lastName: String): domain.feedback.value.NickName {
for (i in lastName.length - 1 downTo 0) {
if (lastName[i] != 'Z') {
return domain.feedback.value.NickName(
lastName.substring(0, i) + (lastName[i].code + 1).toChar() + "A".repeat(
lastName.length - (i + 1)
)
)
}
}
return domain.feedback.value.NickName("A".repeat(Math.max(0, lastName.length + 1)))
}
}
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

import javax.persistence.*

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

import me.nalab.survey.domain.survey.exception.DuplicatedOrderException
import javax.persistence.*
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

enum class ChoiceFormQuestionType {
TENDENCY,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

import me.nalab.core.data.common.TimeBaseEntity
import javax.persistence.*
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

enum class QuestionType {
CHOICE,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

import javax.persistence.*

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

enum class ShortFormQuestionType {
STRENGTH,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

import me.nalab.core.data.common.TimeBaseEntity
import me.nalab.survey.domain.survey.exception.DuplicatedOrderException
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

import javax.persistence.Column
import javax.persistence.Embeddable
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

import org.springframework.data.jpa.repository.JpaRepository

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey
package domain.survey

import me.nalab.core.data.common.TimeBaseEntity
import me.nalab.survey.domain.survey.value.ImageUrl
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey.exception
package domain.survey.exception

class DuplicatedOrderException internal constructor(duplicated: Int, orders: HashSet<Int>) :
RuntimeException(
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey.value
package domain.survey.value

import javax.persistence.Column
import javax.persistence.Embeddable
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey.value
package domain.survey.value

import javax.persistence.Column
import javax.persistence.Embeddable
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package me.nalab.survey.domain.survey.value
package domain.survey.value

import javax.persistence.Column
import javax.persistence.Embeddable
Expand Down
12 changes: 0 additions & 12 deletions survey/build.gradle
Original file line number Diff line number Diff line change
@@ -1,12 +0,0 @@
repositories {
mavenCentral()
}

dependencies {
implementation project(":core:data")
implementation project(":core:time")

implementation "org.springframework.boot:spring-boot-starter-data-jpa"

testRuntimeOnly "com.h2database:h2"
}

This file was deleted.

0 comments on commit 3536b32

Please sign in to comment.