Sat, 24 Oct 2020 12:09:08 +0200
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 |