mirror of
https://gitlab.dit.htwk-leipzig.de/htwk-software/htwkalender-pwa.git
synced 2025-07-16 17:48:51 +02:00
feat:#53 added check if already added
This commit is contained in:
@ -185,7 +185,7 @@ func GetPlanForModules(app *pocketbase.PocketBase, modules map[string]model.Feed
|
|||||||
|
|
||||||
var selectedModulesQuery = buildIcalQueryForModules(moduleBatch)
|
var selectedModulesQuery = buildIcalQueryForModules(moduleBatch)
|
||||||
// get all events from event records in the events collection
|
// get all events from event records in the events collection
|
||||||
err := app.Dao().DB().Select("*").From("events").Where(selectedModulesQuery).All(&events)
|
err := app.Dao().DB().Select("*").From("events").Where(selectedModulesQuery).OrderBy("start").All(&events)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,6 @@ import (
|
|||||||
"github.com/pocketbase/pocketbase/daos"
|
"github.com/pocketbase/pocketbase/daos"
|
||||||
"htwkalender/model"
|
"htwkalender/model"
|
||||||
database "htwkalender/service/db"
|
database "htwkalender/service/db"
|
||||||
"htwkalender/service/functions"
|
|
||||||
localTime "htwkalender/service/functions/time"
|
localTime "htwkalender/service/functions/time"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
"strings"
|
"strings"
|
||||||
@ -55,87 +54,69 @@ func ClearFeeds(db *daos.Dao, months int, clock localTime.Clock) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func CombineEventsInFeed(events model.Events) model.Events {
|
func CombineEventsInFeed(events model.Events) model.Events {
|
||||||
// Combine events with the same Prof, Name, Start and End time into one event
|
// Combine events with the same name, start, end and course
|
||||||
// if the note is empty then there is no room displayed in the new note
|
combinedEvents := model.Events{events[0]}
|
||||||
// room listing isn't displayed if there is only one event.
|
|
||||||
|
|
||||||
combinedEvents := make(model.Events, 0)
|
for i := 1; i < len(events); i++ {
|
||||||
combinedEvents = append(combinedEvents, events[0])
|
// check if the event is already in the combinedEvents
|
||||||
|
alreadyInCombinedEvents := false
|
||||||
for index1 := 1; index1 < len(events); index1++ {
|
|
||||||
for index2 := 0; index2 < len(combinedEvents); index2++ {
|
|
||||||
|
|
||||||
if events[index1].Name == combinedEvents[index2].Name &&
|
|
||||||
events[index1].Start == combinedEvents[index2].Start &&
|
|
||||||
events[index1].End == combinedEvents[index2].End &&
|
|
||||||
events[index1].Course == combinedEvents[index2].Course {
|
|
||||||
|
|
||||||
// if no notes are present skip
|
|
||||||
if !functions.OnlyWhitespace(events[index1].Notes) {
|
|
||||||
// if combinedEvents notes are empty, add the new notes
|
|
||||||
if functions.OnlyWhitespace(combinedEvents[index2].Notes) {
|
|
||||||
combinedEvents[index2].Notes = descriptionString(events[index1])
|
|
||||||
} else {
|
|
||||||
addNotesIfAlreadyRoomsAdded(events, combinedEvents, index2, index1)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
combineRooms(events, index1, combinedEvents, index2)
|
|
||||||
combineProfs(events, index1, combinedEvents, index2)
|
|
||||||
|
|
||||||
// remove the event from the events list
|
|
||||||
events = append(events[:index1], events[index1+1:]...)
|
|
||||||
|
|
||||||
|
for j := 0; j < len(combinedEvents); j++ {
|
||||||
|
if events[i].Name == combinedEvents[j].Name &&
|
||||||
|
events[i].Start == combinedEvents[j].Start &&
|
||||||
|
events[i].End == combinedEvents[j].End &&
|
||||||
|
events[i].Course == combinedEvents[j].Course {
|
||||||
|
alreadyInCombinedEvents = true
|
||||||
|
combinedEvents[j].Notes = addNotesIfAlreadyRoomsAdded(events, combinedEvents, j, i)
|
||||||
|
combinedEvents[j].Prof = combineProfs(events, i, combinedEvents, j)
|
||||||
|
combinedEvents[j].Rooms = combineRooms(events, i, combinedEvents, j)
|
||||||
break
|
break
|
||||||
|
|
||||||
} else {
|
|
||||||
// if the event is not in the combinedEvents list, add it
|
|
||||||
if index2 == len(combinedEvents)-1 {
|
|
||||||
combinedEvents = append(combinedEvents, events[index1])
|
|
||||||
events = append(events[:index1], events[index1+1:]...)
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if !alreadyInCombinedEvents {
|
||||||
|
combinedEvents = append(combinedEvents, events[i])
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return combinedEvents
|
return combinedEvents
|
||||||
}
|
}
|
||||||
|
|
||||||
func addNotesIfAlreadyRoomsAdded(events model.Events, combinedEvents model.Events, index2 int, index1 int) {
|
func addNotesIfAlreadyRoomsAdded(events model.Events, combinedEvents model.Events, index2 int, index1 int) string {
|
||||||
// check if combinedEvents[index2].Rooms string contains comma "," ,
|
// check if combinedEvents[index2].Rooms string contains comma "," ,
|
||||||
if !strings.Contains(combinedEvents[index2].Rooms, ",") {
|
if !strings.Contains(combinedEvents[index2].Rooms, ",") {
|
||||||
combinedEvents[index2].Notes = descriptionString(combinedEvents[index2]) + "\n" + descriptionString(events[index1])
|
return descriptionString(combinedEvents[index2]) + "\n" + descriptionString(events[index1])
|
||||||
} else {
|
} else {
|
||||||
combinedEvents[index2].Notes += "\n" + descriptionString(events[index1])
|
return combinedEvents[index2].Notes + "\n" + descriptionString(events[index1])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func combineProfs(events model.Events, index1 int, combinedEvents model.Events, index2 int) {
|
func combineProfs(events model.Events, index1 int, combinedEvents model.Events, index2 int) string {
|
||||||
// combine the profs
|
// combine the profs
|
||||||
if events[index1].Prof != "" {
|
if events[index1].Prof != "" {
|
||||||
if combinedEvents[index2].Prof == "" {
|
if combinedEvents[index2].Prof == "" {
|
||||||
combinedEvents[index2].Prof = events[index1].Prof
|
return events[index1].Prof
|
||||||
} else {
|
} else {
|
||||||
if !strings.Contains(combinedEvents[index2].Prof, events[index1].Prof) {
|
if !strings.Contains(combinedEvents[index2].Prof, events[index1].Prof) {
|
||||||
combinedEvents[index2].Prof += ", " + events[index1].Prof
|
return combinedEvents[index2].Prof + ", " + events[index1].Prof
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return combinedEvents[index2].Prof
|
||||||
}
|
}
|
||||||
|
|
||||||
func descriptionString(event model.Event) string {
|
func descriptionString(event model.Event) string {
|
||||||
return event.Rooms + " - " + event.Notes + " (" + event.Prof + ")"
|
return event.Rooms + " - " + event.Notes + " (" + event.Prof + ")"
|
||||||
}
|
}
|
||||||
|
|
||||||
func combineRooms(events model.Events, index1 int, combinedEvents model.Events, index2 int) {
|
func combineRooms(events model.Events, index1 int, combinedEvents model.Events, index2 int) string {
|
||||||
// combine the rooms
|
// combine the rooms
|
||||||
if events[index1].Rooms != "" {
|
if events[index1].Rooms != "" {
|
||||||
if combinedEvents[index2].Rooms == "" {
|
if combinedEvents[index2].Rooms == "" {
|
||||||
combinedEvents[index2].Rooms = events[index1].Rooms
|
return events[index1].Rooms
|
||||||
} else {
|
} else {
|
||||||
if !strings.Contains(combinedEvents[index2].Rooms, events[index1].Rooms) {
|
if !strings.Contains(combinedEvents[index2].Rooms, events[index1].Rooms) {
|
||||||
combinedEvents[index2].Rooms += ", " + events[index1].Rooms
|
return combinedEvents[index2].Rooms + ", " + events[index1].Rooms
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return combinedEvents[index2].Rooms
|
||||||
}
|
}
|
||||||
|
@ -141,6 +141,47 @@ func TestCombineEventsInFeed(t *testing.T) {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "CannotCombineEventsInFeed",
|
||||||
|
args: args{
|
||||||
|
events: model.Events{
|
||||||
|
{
|
||||||
|
Name: "Modellierung",
|
||||||
|
Start: mockTime.ParseAsTypesDatetime(time.Date(2023, 12, 1, 0, 0, 0, 0, time.UTC)),
|
||||||
|
End: mockTime.ParseAsTypesDatetime(time.Date(2023, 12, 1, 4, 0, 0, 0, time.UTC)),
|
||||||
|
Prof: "Prof. Bunt",
|
||||||
|
Rooms: "LI001",
|
||||||
|
Notes: "Gruppe 2",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Name: "Modellierung - 2",
|
||||||
|
Start: mockTime.ParseAsTypesDatetime(time.Date(2023, 12, 1, 0, 0, 0, 0, time.UTC)),
|
||||||
|
End: mockTime.ParseAsTypesDatetime(time.Date(2023, 12, 1, 4, 0, 0, 0, time.UTC)),
|
||||||
|
Prof: "Prof. Bunt",
|
||||||
|
Rooms: "LI002",
|
||||||
|
Notes: "Gruppe 1",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
want: model.Events{
|
||||||
|
{
|
||||||
|
Name: "Modellierung",
|
||||||
|
Start: mockTime.ParseAsTypesDatetime(time.Date(2023, 12, 1, 0, 0, 0, 0, time.UTC)),
|
||||||
|
End: mockTime.ParseAsTypesDatetime(time.Date(2023, 12, 1, 4, 0, 0, 0, time.UTC)),
|
||||||
|
Prof: "Prof. Bunt",
|
||||||
|
Rooms: "LI001",
|
||||||
|
Notes: "Gruppe 2",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Name: "Modellierung - 2",
|
||||||
|
Start: mockTime.ParseAsTypesDatetime(time.Date(2023, 12, 1, 0, 0, 0, 0, time.UTC)),
|
||||||
|
End: mockTime.ParseAsTypesDatetime(time.Date(2023, 12, 1, 4, 0, 0, 0, time.UTC)),
|
||||||
|
Prof: "Prof. Bunt",
|
||||||
|
Rooms: "LI002",
|
||||||
|
Notes: "Gruppe 1",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
for _, tt := range testCases {
|
for _, tt := range testCases {
|
||||||
t.Run(tt.name, func(t *testing.T) {
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
@ -21,6 +21,7 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"htwkalender/model"
|
"htwkalender/model"
|
||||||
"htwkalender/service/db"
|
"htwkalender/service/db"
|
||||||
|
"htwkalender/service/feed"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/jordic/goics"
|
"github.com/jordic/goics"
|
||||||
@ -62,7 +63,7 @@ func createFeedForToken(app *pocketbase.PocketBase, modules map[string]model.Fee
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Combine Events
|
// Combine Events
|
||||||
//events = feed.CombineEventsInFeed(events)
|
events = feed.CombineEventsInFeed(events)
|
||||||
|
|
||||||
b := bytes.Buffer{}
|
b := bytes.Buffer{}
|
||||||
goics.NewICalEncode(&b).Encode(IcalModel{Events: events, Mapping: modules})
|
goics.NewICalEncode(&b).Encode(IcalModel{Events: events, Mapping: modules})
|
||||||
|
Reference in New Issue
Block a user