Add auto constraint check
This commit is contained in:
parent
e7bdaabca8
commit
7d3a279ff1
4 changed files with 76 additions and 26 deletions
|
@ -49,6 +49,26 @@ class Calendar(calendar: HTMLElement) : View(calendar) {
|
||||||
Orientation.ROOM_TO_TIME
|
Orientation.ROOM_TO_TIME
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private var autoCheck: Boolean = false
|
||||||
|
|
||||||
|
fun autoCheck() {
|
||||||
|
if (autoCheck) checkConstraints()
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun checkConstraints() {
|
||||||
|
launch {
|
||||||
|
val errors = ScheduleRepository.checkConstraints()
|
||||||
|
|
||||||
|
for ((s, l) in errors.map) {
|
||||||
|
for (entry in body.calendarEntries) {
|
||||||
|
if (entry.scheduleId == s) {
|
||||||
|
entry.setError(l)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
init {
|
init {
|
||||||
scroll += calendarTable
|
scroll += calendarTable
|
||||||
|
|
||||||
|
@ -56,18 +76,29 @@ class Calendar(calendar: HTMLElement) : View(calendar) {
|
||||||
CalendarEdit(this, calendar.querySelector(".calendar-edit") as HTMLElement)
|
CalendarEdit(this, calendar.querySelector(".calendar-edit") as HTMLElement)
|
||||||
}
|
}
|
||||||
|
|
||||||
(document.getElementById("calendar-check-constraints") as? HTMLElement)?.let { wrap(it) }
|
val checkConstraintsBtn =
|
||||||
?.onClick?.addListener {
|
(document.getElementById("calendar-check-constraints") as? HTMLElement)?.let { wrap(it) }
|
||||||
launch {
|
if (checkConstraintsBtn != null) {
|
||||||
val errors = ScheduleRepository.checkConstraints()
|
checkConstraintsBtn.onClick.addListener {
|
||||||
|
checkConstraints()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for ((s, l) in errors.map) {
|
val autoCheckConstraintsBtn =
|
||||||
|
(document.getElementById("calendar-auto-check-constraints") as? HTMLElement)?.let { wrap(it) }
|
||||||
|
if (autoCheckConstraintsBtn != null) {
|
||||||
|
autoCheckConstraintsBtn.onClick.addListener {
|
||||||
|
if (autoCheck) {
|
||||||
for (entry in body.calendarEntries) {
|
for (entry in body.calendarEntries) {
|
||||||
if (entry.scheduleId == s) {
|
entry.setError(emptyList())
|
||||||
entry.setError(l)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
autoCheck = false
|
||||||
|
} else {
|
||||||
|
autoCheck = true
|
||||||
|
autoCheck()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
autoCheckConstraintsBtn.classList["btn-primary"] = autoCheck
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -243,6 +243,8 @@ class CalendarEntry(private val calendar: CalendarBody, view: HTMLElement) : Vie
|
||||||
if (cell != null && cell.html != html.parentElement) {
|
if (cell != null && cell.html != html.parentElement) {
|
||||||
cell += this
|
cell += this
|
||||||
}
|
}
|
||||||
|
|
||||||
|
calendar.calendar.autoCheck()
|
||||||
}
|
}
|
||||||
|
|
||||||
fun load(workGroup: WorkGroup) {
|
fun load(workGroup: WorkGroup) {
|
||||||
|
|
|
@ -216,12 +216,6 @@ fun Route.calendar() {
|
||||||
|
|
||||||
val range = ScheduleRepository.getDayRange()
|
val range = ScheduleRepository.getDayRange()
|
||||||
|
|
||||||
/*
|
|
||||||
if (!editable && day !in range) {
|
|
||||||
return@get
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
val rooms = RoomRepository.all()
|
val rooms = RoomRepository.all()
|
||||||
val tracks = TrackRepository.all()
|
val tracks = TrackRepository.all()
|
||||||
|
|
||||||
|
@ -283,20 +277,30 @@ fun Route.calendar() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
div("header-right") {
|
div("header-right") {
|
||||||
a("$prefix/calendar/$day/rtt", classes = "form-btn") {
|
div {
|
||||||
+"Vertikal"
|
a("$prefix/calendar/$day/rtt", classes = "form-btn") {
|
||||||
}
|
+"Vertikal"
|
||||||
a("$prefix/calendar/$day/ttr", classes = "form-btn") {
|
}
|
||||||
+"Horizontal"
|
a("$prefix/calendar/$day/ttr", classes = "form-btn") {
|
||||||
|
+"Horizontal"
|
||||||
|
}
|
||||||
|
if (editable) {
|
||||||
|
button(classes = "form-btn") {
|
||||||
|
id = "calendar-edit-button"
|
||||||
|
+"Bearbeiten"
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (editable) {
|
if (editable) {
|
||||||
button(classes = "form-btn") {
|
div {
|
||||||
id = "calendar-check-constraints"
|
button(classes = "form-btn") {
|
||||||
+"Constraints überprüfen"
|
id = "calendar-check-constraints"
|
||||||
}
|
+"Constraints überprüfen"
|
||||||
button(classes = "form-btn") {
|
}
|
||||||
id = "calendar-edit-button"
|
button(classes = "form-btn") {
|
||||||
+"Bearbeiten"
|
id = "calendar-auto-check-constraints"
|
||||||
|
+"Auto check"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,8 @@ import io.ktor.application.call
|
||||||
import io.ktor.http.HttpStatusCode
|
import io.ktor.http.HttpStatusCode
|
||||||
import io.ktor.routing.Route
|
import io.ktor.routing.Route
|
||||||
import io.ktor.routing.get
|
import io.ktor.routing.get
|
||||||
|
import kotlinx.html.currentTimeMillis
|
||||||
|
import kotlin.concurrent.thread
|
||||||
|
|
||||||
object PushService {
|
object PushService {
|
||||||
|
|
||||||
|
@ -101,4 +103,15 @@ fun Route.pushService() {
|
||||||
WorkGroupRepository.registerPushService()
|
WorkGroupRepository.registerPushService()
|
||||||
PostRepository.registerPushService()
|
PostRepository.registerPushService()
|
||||||
AnnouncementRepository.registerPushService()
|
AnnouncementRepository.registerPushService()
|
||||||
|
|
||||||
|
thread(
|
||||||
|
start = true,
|
||||||
|
isDaemon = true,
|
||||||
|
name = "PushServiceGC"
|
||||||
|
) {
|
||||||
|
while (true) {
|
||||||
|
PushService.gc(currentTimeMillis() - 1000 * 60)
|
||||||
|
Thread.sleep(1000 * 60 * 5)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue