Links vereinheitlicht + Beilage

This commit is contained in:
Simon Martens
2025-09-22 08:21:18 +02:00
parent f2829a4bad
commit 350631f6b4
6 changed files with 96 additions and 79 deletions

View File

@@ -63,16 +63,39 @@ func GetPieceWithPage(kgpz *xmlmodels.Library) fiber.Handler {
return c.SendStatus(fiber.StatusNotFound)
}
// Handle optional page parameter
// Handle optional page parameter (supports regular pages and Beilage format like b1-1, b2-2)
pageParam := c.Params("page")
var targetPage int
var beilageNumber int
var isBeilage bool
if pageParam != "" {
pi, err := strconv.Atoi(pageParam)
if err != nil || pi < 1 {
logging.Error(err, "Page is not a valid number")
return c.SendStatus(fiber.StatusNotFound)
if strings.HasPrefix(pageParam, "b") {
// Handle Beilage format: b1-1, b2-2, etc.
parts := strings.Split(pageParam[1:], "-")
if len(parts) == 2 {
beilageNum, beilageErr := strconv.Atoi(parts[0])
pageNum, pageErr := strconv.Atoi(parts[1])
if beilageErr == nil && pageErr == nil && beilageNum > 0 && pageNum > 0 {
beilageNumber = beilageNum
targetPage = pageNum
isBeilage = true
} else {
logging.Error(nil, "Beilage page format is invalid")
return c.SendStatus(fiber.StatusNotFound)
}
} else {
logging.Error(nil, "Beilage page format is invalid")
return c.SendStatus(fiber.StatusNotFound)
}
} else {
// Handle regular page number
pi, err := strconv.Atoi(pageParam)
if err != nil || pi < 1 {
logging.Error(err, "Page is not a valid number")
return c.SendStatus(fiber.StatusNotFound)
}
targetPage = pi
}
targetPage = pi
}
// Parse the generated ID format: YYYY-NNN-PPP
@@ -108,20 +131,27 @@ func GetPieceWithPage(kgpz *xmlmodels.Library) fiber.Handler {
// If a page was specified, validate it exists in this piece
if targetPage > 0 {
pageExists := false
for _, pageEntry := range pieceView.AllPages {
if pageEntry.PageNumber == targetPage {
pageExists = true
break
if isBeilage {
// For Beilage pages, validation is more complex
// For now, we'll accept any valid Beilage format and let the template handle validation
logging.Debug(fmt.Sprintf("Accessing Beilage %d, page %d in piece %s", beilageNumber, targetPage, id))
} else {
// For regular pages, validate against the piece's page range
pageExists := false
for _, pageEntry := range pieceView.AllPages {
if pageEntry.PageNumber == targetPage {
pageExists = true
break
}
}
if !pageExists {
logging.Debug(fmt.Sprintf("Page %d not found in piece %s", targetPage, id))
return c.SendStatus(fiber.StatusNotFound)
}
}
if !pageExists {
logging.Debug(fmt.Sprintf("Page %d not found in piece %s", targetPage, id))
return c.SendStatus(fiber.StatusNotFound)
}
}
return c.Render("/piece/", fiber.Map{"model": pieceView, "pieceId": id, "targetPage": targetPage}, "fullwidth")
return c.Render("/piece/", fiber.Map{"model": pieceView, "pieceId": id, "targetPage": targetPage, "beilageNumber": beilageNumber, "isBeilage": isBeilage}, "fullwidth")
}
}