src/main/kotlin/de/uapcore/lightpit/viewmodel/Issues.kt

Tue, 30 Jul 2024 18:53:39 +0200

author
Mike Becker <universe@uap-core.de>
date
Tue, 30 Jul 2024 18:53:39 +0200
changeset 307
23fe9f174d2d
parent 292
703591e739f4
child 311
bf67e0ff7131
permissions
-rw-r--r--

add filter for assignee - fixes #403

184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * Copyright 2021 Mike Becker. All rights reserved.
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 *
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 * Redistribution and use in source and binary forms, with or without
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 * modification, are permitted provided that the following conditions are met:
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 *
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 * 1. Redistributions of source code must retain the above copyright
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 * notice, this list of conditions and the following disclaimer.
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 *
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 * 2. Redistributions in binary form must reproduce the above copyright
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 * notice, this list of conditions and the following disclaimer in the
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * documentation and/or other materials provided with the distribution.
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 *
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 */
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 package de.uapcore.lightpit.viewmodel
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
28 import com.vladsch.flexmark.ext.gfm.strikethrough.StrikethroughExtension
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
29 import com.vladsch.flexmark.ext.tables.TablesExtension
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30 import com.vladsch.flexmark.html.HtmlRenderer
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
31 import com.vladsch.flexmark.parser.Parser
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
32 import com.vladsch.flexmark.util.data.MutableDataSet
234
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
33 import com.vladsch.flexmark.util.data.SharedDataKeys
268
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
34 import de.uapcore.lightpit.HttpRequest
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
35 import de.uapcore.lightpit.entities.*
263
aa22103809cd #29 add possibility to relate issues
Mike Becker <universe@uap-core.de>
parents: 260
diff changeset
36 import de.uapcore.lightpit.types.*
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
37 import kotlin.math.roundToInt
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
38
249
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
39 class IssueSorter(private vararg val criteria: Criteria) : Comparator<Issue> {
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
40 enum class Field {
271
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
41 DONE, PHASE, STATUS, CATEGORY, ETA, UPDATED, CREATED;
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
42
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
43 val resourceKey: String by lazy {
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
44 if (this == DONE) "issue.filter.sort.done"
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
45 else if (this == PHASE) "issue.filter.sort.phase"
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
46 else "issue.${this.name.lowercase()}"
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
47 }
249
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
48 }
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
49
271
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
50 data class Criteria(val field: Field, val asc: Boolean = true) {
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
51 override fun toString(): String {
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
52 return "$field.$asc"
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
53 }
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
54 }
249
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
55
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
56 override fun compare(left: Issue, right: Issue): Int {
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
57 if (left == right) {
260
fb2ae2d63a56 some minor style fixes
Mike Becker <universe@uap-core.de>
parents: 250
diff changeset
58 return 0
249
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
59 }
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
60 for (c in criteria) {
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
61 val result = when (c.field) {
267
d8ec2d8ffa82 fix default sort criteria
Mike Becker <universe@uap-core.de>
parents: 265
diff changeset
62 Field.PHASE -> left.status.phase.compareTo(right.status.phase)
d8ec2d8ffa82 fix default sort criteria
Mike Becker <universe@uap-core.de>
parents: 265
diff changeset
63 Field.DONE -> (left.status.phase == IssueStatusPhase.Done).compareTo(right.status.phase == IssueStatusPhase.Done)
265
6a21bb926e02 add more possible sort criteria
Mike Becker <universe@uap-core.de>
parents: 263
diff changeset
64 Field.STATUS -> left.status.compareTo(right.status)
6a21bb926e02 add more possible sort criteria
Mike Becker <universe@uap-core.de>
parents: 263
diff changeset
65 Field.CATEGORY -> left.category.compareTo(right.category)
6a21bb926e02 add more possible sort criteria
Mike Becker <universe@uap-core.de>
parents: 263
diff changeset
66 Field.ETA -> left.compareEtaTo(right.eta)
249
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
67 Field.UPDATED -> left.updated.compareTo(right.updated)
265
6a21bb926e02 add more possible sort criteria
Mike Becker <universe@uap-core.de>
parents: 263
diff changeset
68 Field.CREATED -> left.created.compareTo(right.created)
249
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
69 }
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
70 if (result != 0) {
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
71 return if (c.asc) result else -result
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
72 }
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
73 }
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
74 return 0
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
75 }
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
76 }
6bded7090719 move IssueSorter to viewmodel package
Mike Becker <universe@uap-core.de>
parents: 234
diff changeset
77
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
78 class IssueSummary {
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
79 var open = 0
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
80 var active = 0
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
81 var done = 0
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
82
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
83 val total get() = open + active + done
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
84
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
85 val openPercent get() = 100 - activePercent - donePercent
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
86 val activePercent get() = if (total > 0) (100f * active / total).roundToInt() else 0
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
87 val donePercent get() = if (total > 0) (100f * done / total).roundToInt() else 100
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
88
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
89 /**
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
90 * Adds the specified issue to the summary by incrementing the respective counter.
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
91 * @param issue the issue
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
92 */
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
93 fun add(issue: Issue) {
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
94 when (issue.status.phase) {
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
95 IssueStatusPhase.Open -> open++
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
96 IssueStatusPhase.WorkInProgress -> active++
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
97 IssueStatusPhase.Done -> done++
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
98 }
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
99 }
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
100 }
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
101
284
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
102 data class CommitLink(val url: String, val hash: String, val message: String)
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
103
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
104 class IssueDetailView(
292
703591e739f4 add possibility to show issues w/o version or component - fixes #335
Mike Becker <universe@uap-core.de>
parents: 291
diff changeset
105 val pathInfos: PathInfos,
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
106 val issue: Issue,
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
107 val comments: List<IssueComment>,
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
108 val project: Project,
263
aa22103809cd #29 add possibility to relate issues
Mike Becker <universe@uap-core.de>
parents: 260
diff changeset
109 projectIssues: List<Issue>,
aa22103809cd #29 add possibility to relate issues
Mike Becker <universe@uap-core.de>
parents: 260
diff changeset
110 val currentRelations: List<IssueRelation>,
aa22103809cd #29 add possibility to relate issues
Mike Becker <universe@uap-core.de>
parents: 260
diff changeset
111 /**
aa22103809cd #29 add possibility to relate issues
Mike Becker <universe@uap-core.de>
parents: 260
diff changeset
112 * Optional resource key to an error message for the relation editor.
aa22103809cd #29 add possibility to relate issues
Mike Becker <universe@uap-core.de>
parents: 260
diff changeset
113 */
284
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
114 val relationError: String?,
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
115 commitRefs: List<CommitRef>
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
116 ) : View() {
291
bcf05cccac6f replace Enum.values() with Enum.entries
Mike Becker <universe@uap-core.de>
parents: 284
diff changeset
117 val relationTypes = RelationType.entries
263
aa22103809cd #29 add possibility to relate issues
Mike Becker <universe@uap-core.de>
parents: 260
diff changeset
118 val linkableIssues = projectIssues.filterNot { it.id == issue.id }
284
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
119 val commitLinks: List<CommitLink>
263
aa22103809cd #29 add possibility to relate issues
Mike Becker <universe@uap-core.de>
parents: 260
diff changeset
120
234
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
121 private val parser: Parser
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
122 private val renderer: HtmlRenderer
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
123
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
124 init {
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
125 val options = MutableDataSet()
234
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
126 .set(SharedDataKeys.EXTENSIONS, listOf(TablesExtension.create(), StrikethroughExtension.create()))
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
127 parser = Parser.builder(options).build()
268
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
128 renderer = HtmlRenderer.builder(
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
129 options
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
130 .set(HtmlRenderer.ESCAPE_HTML, true)
234
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
131 ).build()
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
132
234
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
133 issue.description = formatMarkdown(issue.description ?: "")
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
134 for (comment in comments) {
234
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
135 comment.commentFormatted = formatMarkdown(comment.comment)
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
136 }
284
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
137
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
138 val commitBaseUrl = project.repoUrl
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
139 commitLinks = (if (commitBaseUrl == null || project.vcs == VcsType.None) emptyList() else commitRefs.map {
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
140 CommitLink(buildCommitUrl(commitBaseUrl, project.vcs, it.hash), it.hash, it.message)
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
141 })
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
142 }
234
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
143
284
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
144 private fun buildCommitUrl(baseUrl: String, vcs: VcsType, hash: String): String =
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
145 with (StringBuilder(baseUrl)) {
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
146 if (!endsWith("/")) append('/')
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
147 when (vcs) {
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
148 VcsType.Mercurial -> append("rev/")
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
149 else -> append("commit/")
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
150 }
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
151 append(hash)
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
152 toString()
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
153 }
671c1c8fbf1c add full support for commit references - fixes #276
Mike Becker <universe@uap-core.de>
parents: 271
diff changeset
154
234
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
155 private fun formatEmojis(text: String) = text
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
156 .replace("(/)", "&#9989;")
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
157 .replace("(x)", "&#10060;")
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
158 .replace("(!)", "&#9889;")
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
159
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
160 private fun formatMarkdown(text: String) =
d71bc6db42ef add three emoji sequences (experimental feature)
Mike Becker <universe@uap-core.de>
parents: 231
diff changeset
161 renderer.render(parser.parse(formatEmojis(text)))
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
162 }
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
163
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
164 class IssueEditView(
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
165 val issue: Issue,
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
166 val versions: List<Version>,
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
167 val components: List<Component>,
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
168 val users: List<User>,
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
169 val project: Project, // TODO: allow null values to create issues from the IssuesServlet
292
703591e739f4 add possibility to show issues w/o version or component - fixes #335
Mike Becker <universe@uap-core.de>
parents: 291
diff changeset
170 val pathInfos: PathInfos
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
171 ) : EditView() {
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
172
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
173 val versionsUpcoming: List<Version>
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
174 val versionsRecent: List<Version>
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
175
291
bcf05cccac6f replace Enum.values() with Enum.entries
Mike Becker <universe@uap-core.de>
parents: 284
diff changeset
176 val issueStatus = IssueStatus.entries
bcf05cccac6f replace Enum.values() with Enum.entries
Mike Becker <universe@uap-core.de>
parents: 284
diff changeset
177 val issueCategory = IssueCategory.entries
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
178
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
179 init {
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
180 val recent = mutableListOf<Version>()
231
dcb1d5a7ea3a #163 removes multi selection for versions
Mike Becker <universe@uap-core.de>
parents: 207
diff changeset
181 issue.affected?.let { recent.add(it) }
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
182 val upcoming = mutableListOf<Version>()
231
dcb1d5a7ea3a #163 removes multi selection for versions
Mike Becker <universe@uap-core.de>
parents: 207
diff changeset
183 issue.resolved?.let { upcoming.add(it) }
dcb1d5a7ea3a #163 removes multi selection for versions
Mike Becker <universe@uap-core.de>
parents: 207
diff changeset
184
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
185 for (v in versions) {
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
186 if (v.status.isReleased) {
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
187 if (v.status != VersionStatus.Deprecated) recent.add(v)
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
188 } else {
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
189 upcoming.add(v)
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
190 }
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
191 }
186
05eec764facd fixes some minor migration regressions
Mike Becker <universe@uap-core.de>
parents: 184
diff changeset
192 versionsRecent = recent.distinct()
05eec764facd fixes some minor migration regressions
Mike Becker <universe@uap-core.de>
parents: 184
diff changeset
193 versionsUpcoming = upcoming.distinct()
184
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
194 }
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
195 }
e8eecee6aadf completes kotlin migration
Mike Becker <universe@uap-core.de>
parents:
diff changeset
196
268
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
197 class IssueFilter(http: HttpRequest) {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
198
291
bcf05cccac6f replace Enum.values() with Enum.entries
Mike Becker <universe@uap-core.de>
parents: 284
diff changeset
199 val issueStatus = IssueStatus.entries
bcf05cccac6f replace Enum.values() with Enum.entries
Mike Becker <universe@uap-core.de>
parents: 284
diff changeset
200 val issueCategory = IssueCategory.entries
bcf05cccac6f replace Enum.values() with Enum.entries
Mike Becker <universe@uap-core.de>
parents: 284
diff changeset
201 val sortCriteria = IssueSorter.Field.entries.flatMap { listOf(IssueSorter.Criteria(it, true), IssueSorter.Criteria(it, false)) }
268
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
202 val flagIncludeDone = "f.0"
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
203 val flagMine = "f.1"
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
204 val flagBlocker = "f.2"
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
205
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
206 val includeDone: Boolean = evalFlag(http, flagIncludeDone)
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
207 val onlyMine: Boolean = evalFlag(http, flagMine)
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
208 val onlyBlocker: Boolean = evalFlag(http, flagBlocker)
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
209 val status: List<IssueStatus> = evalEnum(http, "s")
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
210 val category: List<IssueCategory> = evalEnum(http, "c")
307
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
211 val assignee: List<Int> = evalInts(http, "u")
268
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
212
271
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
213 val sortPrimary: IssueSorter.Criteria = evalSort(http, "primary", IssueSorter.Criteria(IssueSorter.Field.DONE))
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
214 val sortSecondary: IssueSorter.Criteria = evalSort(http, "secondary", IssueSorter.Criteria(IssueSorter.Field.ETA))
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
215 val sortTertiary: IssueSorter.Criteria = evalSort(http, "tertiary", IssueSorter.Criteria(IssueSorter.Field.UPDATED, false))
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
216
307
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
217 fun containsAssignee(user: User?): Boolean = assignee.contains(user?.id?:-1)
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
218
271
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
219 private fun evalSort(http: HttpRequest, prio: String, defaultValue: IssueSorter.Criteria): IssueSorter.Criteria {
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
220 val param = http.param("sort_$prio")
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
221 if (param != null) {
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
222 http.session.removeAttribute("sort_$prio")
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
223 val p = param.split(".")
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
224 if (p.size > 1) {
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
225 try {
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
226 http.session.setAttribute("sort_$prio", IssueSorter.Criteria(enumValueOf(p[0]), p[1].toBoolean()))
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
227 } catch (_:IllegalArgumentException) {
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
228 // ignore malfored values
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
229 }
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
230 }
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
231 }
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
232 return http.session.getAttribute("sort_$prio") as IssueSorter.Criteria? ?: defaultValue
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
233 }
f8f5e82944fa #15 add sort options
Mike Becker <universe@uap-core.de>
parents: 268
diff changeset
234
268
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
235 private fun evalFlag(http: HttpRequest, name: String): Boolean {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
236 val param = http.paramArray("filter")
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
237 if (param.isNotEmpty()) {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
238 if (param.contains(name)) {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
239 http.session.setAttribute(name, true)
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
240 } else {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
241 http.session.removeAttribute(name)
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
242 }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
243 }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
244 return http.session.getAttribute(name) != null
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
245 }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
246
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
247 private inline fun <reified T : Enum<T>> evalEnum(http: HttpRequest, prefix: String): List<T> {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
248 val sattr = "f.${prefix}"
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
249 val param = http.paramArray("filter")
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
250 if (param.isNotEmpty()) {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
251 val list = param.filter { it.startsWith("${prefix}.") }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
252 .map { it.substring(prefix.length + 1) }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
253 .map {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
254 try {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
255 // quick and very dirty validation
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
256 enumValueOf<T>(it)
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
257 } catch (_: IllegalArgumentException) {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
258 // skip
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
259 }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
260 }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
261 if (list.isEmpty()) {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
262 http.session.removeAttribute(sattr)
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
263 } else {
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
264 http.session.setAttribute(sattr, list.joinToString(","))
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
265 }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
266 }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
267
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
268 return http.session.getAttribute(sattr)
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
269 ?.toString()
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
270 ?.split(",")
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
271 ?.map { enumValueOf(it) }
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
272 ?: emptyList()
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
273 }
307
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
274
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
275 private fun evalInts(http: HttpRequest, prefix: String): List<Int> {
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
276 val sattr = "f.${prefix}"
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
277 val param = http.paramArray("filter")
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
278 if (param.isNotEmpty()) {
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
279 val list = param.filter { it.startsWith("${prefix}.") }
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
280 .map { it.substring(prefix.length + 1) }
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
281 .mapNotNull(String::toIntOrNull)
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
282 if (list.isEmpty()) {
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
283 http.session.removeAttribute(sattr)
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
284 } else {
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
285 http.session.setAttribute(sattr, list.joinToString(","))
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
286 }
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
287 }
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
288
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
289 return http.session.getAttribute(sattr)
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
290 ?.toString()
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
291 ?.split(",")
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
292 ?.map(String::toInt)
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
293 ?: emptyList()
23fe9f174d2d add filter for assignee - fixes #403
Mike Becker <universe@uap-core.de>
parents: 292
diff changeset
294 }
268
ca5501d851fa #15 add issue filters
Mike Becker <universe@uap-core.de>
parents: 267
diff changeset
295 }

mercurial