src/main/kotlin/de/uapcore/lightpit/entities/Issue.kt

Sat, 24 Oct 2020 12:09:08 +0200

author
Mike Becker <universe@uap-core.de>
date
Sat, 24 Oct 2020 12:09:08 +0200
changeset 151
b3f14cd4f3ab
parent 150
822b7e3d064d
child 167
3f30adba1c63
permissions
-rw-r--r--

migrate DataSourceProvider

universe@150 1 /*
universe@150 2 * Copyright 2020 Mike Becker. All rights reserved.
universe@150 3 *
universe@150 4 * Redistribution and use in source and binary forms, with or without
universe@150 5 * modification, are permitted provided that the following conditions are met:
universe@150 6 *
universe@150 7 * 1. Redistributions of source code must retain the above copyright
universe@150 8 * notice, this list of conditions and the following disclaimer.
universe@150 9 *
universe@150 10 * 2. Redistributions in binary form must reproduce the above copyright
universe@150 11 * notice, this list of conditions and the following disclaimer in the
universe@150 12 * documentation and/or other materials provided with the distribution.
universe@150 13 *
universe@150 14 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
universe@150 15 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
universe@150 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
universe@150 17 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
universe@150 18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
universe@150 19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
universe@150 20 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
universe@150 21 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
universe@150 22 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
universe@150 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
universe@150 24 */
universe@150 25
universe@150 26 package de.uapcore.lightpit.entities
universe@150 27
universe@150 28 import java.sql.Date
universe@150 29 import java.sql.Timestamp
universe@150 30 import java.time.Instant
universe@150 31 import kotlin.math.roundToInt
universe@150 32
universe@150 33 data class IssueStatusPhase(val number: Int) {
universe@150 34 companion object {
universe@150 35 val Open = IssueStatusPhase(0)
universe@150 36 val WorkInProgress = IssueStatusPhase(1)
universe@150 37 val Done = IssueStatusPhase(2)
universe@150 38 }
universe@150 39 }
universe@150 40
universe@150 41 enum class IssueStatus(val phase: IssueStatusPhase) {
universe@150 42 InSpecification(IssueStatusPhase.Open),
universe@150 43 ToDo(IssueStatusPhase.Open),
universe@150 44 Scheduled(IssueStatusPhase.Open),
universe@150 45 InProgress(IssueStatusPhase.WorkInProgress),
universe@150 46 InReview(IssueStatusPhase.WorkInProgress),
universe@150 47 Done(IssueStatusPhase.Done),
universe@150 48 Rejected(IssueStatusPhase.Done),
universe@150 49 Withdrawn(IssueStatusPhase.Done),
universe@150 50 Duplicate(IssueStatusPhase.Done);
universe@150 51 }
universe@150 52
universe@150 53 enum class IssueCategory {
universe@150 54 Feature, Improvement, Bug, Task, Test
universe@150 55 }
universe@150 56
universe@150 57 data class Issue(var id: Int) {
universe@150 58
universe@150 59 var project: Project? = null
universe@150 60 var component: Component? = null
universe@150 61
universe@150 62 var status = IssueStatus.InSpecification
universe@150 63 var category = IssueCategory.Feature
universe@150 64
universe@150 65 var subject: String? = null
universe@150 66 var description: String? = null
universe@150 67 var assignee: User? = null
universe@150 68
universe@150 69 var affectedVersions = emptyList<Version>()
universe@150 70 var resolvedVersions = emptyList<Version>()
universe@150 71
universe@150 72 var created: Timestamp = Timestamp.from(Instant.now())
universe@150 73 var updated: Timestamp = Timestamp.from(Instant.now())
universe@150 74 var eta: Date? = null
universe@150 75
universe@150 76 /**
universe@150 77 * An issue is overdue, if it is not done and the ETA is before the current time.
universe@150 78 */
universe@150 79 val overdue get() = status.phase != IssueStatusPhase.Done && eta?.before(Date(System.currentTimeMillis())) ?: false
universe@150 80 }
universe@150 81
universe@150 82 class IssueSummary {
universe@150 83 var open = 0
universe@150 84 var active = 0
universe@150 85 var done = 0
universe@150 86
universe@150 87 val total get() = open + active + done
universe@150 88
universe@150 89 val openPercent get() = 100 - activePercent - donePercent
universe@150 90 val activePercent get() = if (total > 0) (100f * active / total).roundToInt() else 0
universe@150 91 val donePercent get() = if (total > 0) (100f * done / total).roundToInt() else 100
universe@150 92
universe@150 93 /**
universe@150 94 * Adds the specified issue to the summary by incrementing the respective counter.
universe@150 95 * @param issue the issue
universe@150 96 */
universe@150 97 fun add(issue: Issue) {
universe@150 98 when (issue.status.phase) {
universe@150 99 IssueStatusPhase.Open -> open++
universe@150 100 IssueStatusPhase.WorkInProgress -> active++
universe@150 101 IssueStatusPhase.Done -> done++
universe@150 102 }
universe@150 103 }
universe@150 104 }
universe@150 105

mercurial