3 months ago
fix missing localization in RSS feed
fixes #422
--- a/build.gradle.kts Sat Aug 17 12:09:03 2024 +0200 +++ b/build.gradle.kts Sun Oct 06 15:08:50 2024 +0200 @@ -5,7 +5,7 @@ war } group = "de.uapcore" -version = "1.3.0" +version = "1.4.0-snapshot" repositories { mavenCentral() @@ -41,7 +41,7 @@ arrayOf( "jakarta.servlet.jsp.jstl:jakarta.servlet.jsp.jstl-api:3.0.0", "org.glassfish.web:jakarta.servlet.jsp.jstl:3.0.1", - "org.postgresql:postgresql:42.7.3" + "org.postgresql:postgresql:42.7.4" ).forEach { if (libsAreProvided) compileOnly(it) else implementation(it) } @@ -57,7 +57,7 @@ val test by getting { dependencies { implementation("org.jetbrains.kotlin:kotlin-test-junit5") - runtimeOnly("org.junit.jupiter:junit-jupiter-engine:5.10.3") + runtimeOnly("org.junit.jupiter:junit-jupiter-engine:5.11.2") } } }
--- a/src/main/kotlin/de/uapcore/lightpit/servlet/FeedServlet.kt Sat Aug 17 12:09:03 2024 +0200 +++ b/src/main/kotlin/de/uapcore/lightpit/servlet/FeedServlet.kt Sun Oct 06 15:08:50 2024 +0200 @@ -77,14 +77,12 @@ ).joinToString("\n", transform = DiffRow::getOldLine) ) - private fun fullContent(issue: IssueHistoryEntry) = IssueDiff( + private fun fullContent(http: HttpRequest, issue: IssueHistoryEntry) = IssueDiff( issue.issueid, - issue.subject, issue.project, issue.component, - issue.status.name, - issue.category.name, - issue.category.name, + http.i18n("issue.status."+issue.status.name), + http.i18n("issue.category."+issue.category.name), issue.subject, issue.description.replace("\r", ""), issue.assignee, @@ -93,9 +91,9 @@ issue.resolved ) - private fun diffContent(cur: IssueHistoryEntry, next: IssueHistoryEntry): IssueDiff { - val prev = fullContent(next) - val diff = fullContent(cur) + private fun diffContent(http: HttpRequest, cur: IssueHistoryEntry, next: IssueHistoryEntry): IssueDiff { + val prev = fullContent(http, next) + val diff = fullContent(http, cur) val result = diffGenerator.generateDiffRows( listOf( prev.subject, prev.component, prev.status, @@ -129,22 +127,23 @@ * Assumes that [issueEntries] and [commentEntries] are already sorted by timestamp (descending). */ private fun generateFeedEntries( + http: HttpRequest, issueEntries: List<IssueHistoryEntry>, commentEntries: List<IssueCommentHistoryEntry> ): List<IssueFeedEntry> = - (generateIssueFeedEntries(issueEntries) + generateCommentFeedEntries(commentEntries)).sortedByDescending { it.time } + (generateIssueFeedEntries(http, issueEntries) + generateCommentFeedEntries(commentEntries)).sortedByDescending { it.time } - private fun generateIssueFeedEntries(entries: List<IssueHistoryEntry>): List<IssueFeedEntry> = + private fun generateIssueFeedEntries(http: HttpRequest, entries: List<IssueHistoryEntry>): List<IssueFeedEntry> = if (entries.isEmpty()) { emptyList() } else { entries.groupBy { it.issueid }.mapValues { (_, history) -> history.zipWithNext().map { (cur, next) -> IssueFeedEntry( - cur.time, cur.type, issue = diffContent(cur, next) + cur.time, cur.type, issue = diffContent(http, cur, next) ) }.plus( - history.last().let { IssueFeedEntry(it.time, it.type, issue = fullContent(it)) } + history.last().let { IssueFeedEntry(it.time, it.type, issue = fullContent(http, it)) } ) }.flatMap { it.value } } @@ -192,7 +191,7 @@ else -> emptyList() } - http.view = IssueFeed(project, generateFeedEntries(issueHistory, commentHistory)) + http.view = IssueFeed(project, generateFeedEntries(http, issueHistory, commentHistory)) http.renderFeed("issues-feed") } } \ No newline at end of file
--- a/src/main/kotlin/de/uapcore/lightpit/viewmodel/Feeds.kt Sat Aug 17 12:09:03 2024 +0200 +++ b/src/main/kotlin/de/uapcore/lightpit/viewmodel/Feeds.kt Sun Oct 06 15:08:50 2024 +0200 @@ -32,19 +32,20 @@ class IssueDiff( val id: Int, - val currentSubject: String, val project: String, var component: String, var status: String, var category: String, - var currentCategory: String, var subject: String, var description: String, var assignee: String, var eta: String, var affected: String, var resolved: String, -) +) { + var currentCategory: String = category + val currentSubject: String = subject +} class CommentDiff( val issueid: Int,
--- a/src/main/webapp/WEB-INF/changelogs/changelog-de.jspf Sat Aug 17 12:09:03 2024 +0200 +++ b/src/main/webapp/WEB-INF/changelogs/changelog-de.jspf Sun Oct 06 15:08:50 2024 +0200 @@ -24,6 +24,12 @@ --%> <%@ page contentType="text/html;charset=UTF-8" %> +<h3>Version 1.4.0 (Vorschau)</h3> + +<ul> + <li>Status und Kategorie eines Vorgangs sind nun auch im RSS-Feed korrekt lokalisiert.</li> +</ul> + <h3>Version 1.3.0</h3> <ul>
--- a/src/main/webapp/WEB-INF/changelogs/changelog.jspf Sat Aug 17 12:09:03 2024 +0200 +++ b/src/main/webapp/WEB-INF/changelogs/changelog.jspf Sun Oct 06 15:08:50 2024 +0200 @@ -24,6 +24,12 @@ --%> <%@ page contentType="text/html;charset=UTF-8" %> +<h3>Version 1.4.0 (snapshot)</h3> + +<ul> + <li>Fix missing localization for issue status and category in RSS feed.</li> +</ul> + <h3>Version 1.3.0</h3> <ul>
--- a/src/main/webapp/WEB-INF/jsp/issues-feed.jsp Sat Aug 17 12:09:03 2024 +0200 +++ b/src/main/webapp/WEB-INF/jsp/issues-feed.jsp Sun Oct 06 15:08:50 2024 +0200 @@ -65,7 +65,7 @@ <h2><fmt:message key="issue.description"/></h2> <div style="white-space: pre-wrap;">${issue.description}</div> ]]></description> - <category><fmt:message key="issue.category.${issue.currentCategory}"/></category> + <category>${issue.currentCategory}</category> </c:when> <c:when test="${not empty entry.comment}"> <c:set var="comment" value="${entry.comment}"/>