refactor: rebuild application with stl only
This commit is contained in:
parent
0a4efb8630
commit
da24e3c258
10 changed files with 36 additions and 56 deletions
|
|
@ -2,14 +2,12 @@ package controllers
|
|||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"github.com/labstack/echo/v4"
|
||||
)
|
||||
|
||||
func (c *Controller) AddBewertungRoute(ctx echo.Context) error {
|
||||
new := c.ParseBewertungen(ctx)
|
||||
func (c *Controller) AddBewertungRoute(w http.ResponseWriter, r *http.Request) {
|
||||
new := c.ParseBewertungen(w, r)
|
||||
if new.Nachname != "" {
|
||||
*c.Bewertungen = append(*c.Bewertungen, new)
|
||||
}
|
||||
return ctx.Redirect(http.StatusSeeOther, "/")
|
||||
http.Redirect(w, r, "/", http.StatusSeeOther)
|
||||
}
|
||||
|
|
|
|||
|
|
@ -3,11 +3,8 @@ package controllers
|
|||
import (
|
||||
"net/http"
|
||||
"os"
|
||||
|
||||
"github.com/labstack/echo/v4"
|
||||
)
|
||||
|
||||
func (c *Controller) EndRoute(ctx echo.Context) error {
|
||||
func (c *Controller) EndRoute(w http.ResponseWriter, r *http.Request) {
|
||||
os.Exit(0)
|
||||
return ctx.HTML(http.StatusOK, "Tschüss")
|
||||
}
|
||||
|
|
|
|||
|
|
@ -7,10 +7,9 @@ import (
|
|||
"strconv"
|
||||
|
||||
"github.com/jung-kurt/gofpdf"
|
||||
"github.com/labstack/echo/v4"
|
||||
)
|
||||
|
||||
func (c *Controller) ExportBewertungenRoute(ctx echo.Context) error {
|
||||
func (c *Controller) ExportBewertungenRoute(w http.ResponseWriter, r *http.Request) {
|
||||
log.Println("Exporting")
|
||||
pdf := gofpdf.New("P", "mm", "A4", "")
|
||||
pdf.AddPage()
|
||||
|
|
@ -37,7 +36,6 @@ func (c *Controller) ExportBewertungenRoute(ctx echo.Context) error {
|
|||
err := pdf.OutputFileAndClose("bewertungen.pdf")
|
||||
if err != nil {
|
||||
fmt.Println("Fehler beim Exportieren der Bewertungen:", err)
|
||||
return err
|
||||
}
|
||||
return ctx.HTML(http.StatusOK, "Export beendet")
|
||||
fmt.Fprintln(w, "Export beendet")
|
||||
}
|
||||
|
|
|
|||
|
|
@ -3,26 +3,25 @@ package controllers
|
|||
import (
|
||||
"echoTest/models"
|
||||
"echoTest/utils"
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"github.com/labstack/echo/v4"
|
||||
)
|
||||
|
||||
func (c *Controller) ParseBewertungen(ctx echo.Context) models.Bewertung {
|
||||
newName := utils.ValidateName(ctx, c.Bewertungen)
|
||||
vorname := ctx.FormValue("vorname")
|
||||
func (c *Controller) ParseBewertungen(w http.ResponseWriter, r *http.Request) models.Bewertung {
|
||||
newName := utils.ValidateName(r, c.Bewertungen)
|
||||
vorname := r.FormValue("vorname")
|
||||
if c.MaxPunkte.HvMax == 0.00 {
|
||||
hvMax, _ := strconv.ParseFloat(ctx.FormValue("hv_max"), 64)
|
||||
lvMax, _ := strconv.ParseFloat(ctx.FormValue("lv_max"), 64)
|
||||
hvGewichtung, _ := strconv.ParseFloat(ctx.FormValue("hv_gewichtung"), 64)
|
||||
lvGewichtung, _ := strconv.ParseFloat(ctx.FormValue("lv_gewichtung"), 64)
|
||||
hvMax, _ := strconv.ParseFloat(r.FormValue("hv_max"), 64)
|
||||
lvMax, _ := strconv.ParseFloat(r.FormValue("lv_max"), 64)
|
||||
hvGewichtung, _ := strconv.ParseFloat(r.FormValue("hv_gewichtung"), 64)
|
||||
lvGewichtung, _ := strconv.ParseFloat(r.FormValue("lv_gewichtung"), 64)
|
||||
c.MaxPunkte.HvMax = hvMax
|
||||
c.MaxPunkte.LvMax = lvMax
|
||||
c.MaxPunkte.LvGewichtung = lvGewichtung
|
||||
c.MaxPunkte.HvGewichtung = hvGewichtung
|
||||
}
|
||||
hvPunkte, _ := strconv.ParseFloat(ctx.FormValue("hv_punkte"), 64)
|
||||
lvPunkte, _ := strconv.ParseFloat(ctx.FormValue("lv_punkte"), 64)
|
||||
hvPunkte, _ := strconv.ParseFloat(r.FormValue("hv_punkte"), 64)
|
||||
lvPunkte, _ := strconv.ParseFloat(r.FormValue("lv_punkte"), 64)
|
||||
hvProzent := 100.00 / c.MaxPunkte.HvMax * hvPunkte
|
||||
lvProzent := 100.00 / c.MaxPunkte.LvMax * lvPunkte
|
||||
hvNote := utils.SetNote(hvProzent)
|
||||
|
|
|
|||
|
|
@ -2,10 +2,9 @@ package controllers
|
|||
|
||||
import (
|
||||
"echoTest/templates"
|
||||
|
||||
"github.com/labstack/echo/v4"
|
||||
"net/http"
|
||||
)
|
||||
|
||||
func (c *Controller) RenderBewertungenRoute(ctx echo.Context) error {
|
||||
return templates.BewertungenPage(*c.Bewertungen, *c.MaxPunkte).Render(ctx.Request().Context(), ctx.Response().Writer)
|
||||
func (c *Controller) RenderBewertungenRoute(w http.ResponseWriter, r *http.Request) {
|
||||
templates.BewertungenPage(*c.Bewertungen, *c.MaxPunkte).Render(r.Context(), w)
|
||||
}
|
||||
|
|
|
|||
|
|
@ -3,13 +3,12 @@ package controllers
|
|||
import (
|
||||
"echoTest/models"
|
||||
"echoTest/templates"
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"github.com/labstack/echo/v4"
|
||||
)
|
||||
|
||||
func (c *Controller) ToggleWertungRoute(ctx echo.Context) error {
|
||||
id, _ := strconv.Atoi(ctx.Param("id"))
|
||||
func (c *Controller) ToggleWertungRoute(w http.ResponseWriter, r *http.Request) {
|
||||
id, _ := strconv.Atoi(r.PathValue("id"))
|
||||
var updatedBewertung models.Bewertung
|
||||
for i, bewertung := range *c.Bewertungen {
|
||||
if bewertung.ID == id {
|
||||
|
|
@ -19,5 +18,5 @@ func (c *Controller) ToggleWertungRoute(ctx echo.Context) error {
|
|||
}
|
||||
}
|
||||
// return c.CreateBewertungNode(updatedBewertung).Render(ctx.Request().Context(), ctx.Response().Writer)
|
||||
return templates.BewertungRow(updatedBewertung).Render(ctx.Request().Context(), ctx.Response().Writer)
|
||||
templates.BewertungRow(updatedBewertung).Render(r.Context(), w)
|
||||
}
|
||||
|
|
|
|||
4
go.mod
4
go.mod
|
|
@ -1,6 +1,6 @@
|
|||
module echoTest
|
||||
|
||||
go 1.21.5
|
||||
go 1.23.1
|
||||
|
||||
require (
|
||||
github.com/a-h/templ v0.2.793
|
||||
|
|
@ -9,7 +9,6 @@ require (
|
|||
)
|
||||
|
||||
require (
|
||||
github.com/golang-jwt/jwt v3.2.2+incompatible // indirect
|
||||
github.com/labstack/gommon v0.4.2 // indirect
|
||||
github.com/mattn/go-colorable v0.1.13 // indirect
|
||||
github.com/mattn/go-isatty v0.0.20 // indirect
|
||||
|
|
@ -19,5 +18,4 @@ require (
|
|||
golang.org/x/net v0.28.0 // indirect
|
||||
golang.org/x/sys v0.24.0 // indirect
|
||||
golang.org/x/text v0.17.0 // indirect
|
||||
golang.org/x/time v0.6.0 // indirect
|
||||
)
|
||||
|
|
|
|||
4
go.sum
4
go.sum
|
|
@ -4,8 +4,6 @@ github.com/boombuler/barcode v1.0.0/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl
|
|||
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/golang-jwt/jwt v3.2.2+incompatible h1:IfV12K8xAKAnZqdXVzCZ+TOjboZ2keLg81eXfW3O+oY=
|
||||
github.com/golang-jwt/jwt v3.2.2+incompatible/go.mod h1:8pz2t5EyA70fFQQSrl6XZXzqecmYZeUEB8OUGHkxJ+I=
|
||||
github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI=
|
||||
github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
|
||||
github.com/jung-kurt/gofpdf v1.0.0/go.mod h1:7Id9E/uU8ce6rXgefFLlgrJj/GYY22cpxn+r32jIOes=
|
||||
|
|
@ -44,7 +42,5 @@ golang.org/x/sys v0.24.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
|||
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||
golang.org/x/text v0.17.0 h1:XtiM5bkSOt+ewxlOE/aE/AKEHibwj/6gvWMl9Rsh0Qc=
|
||||
golang.org/x/text v0.17.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY=
|
||||
golang.org/x/time v0.6.0 h1:eTDhh4ZXt5Qf0augr54TN6suAUudPcawVZeIAPU7D4U=
|
||||
golang.org/x/time v0.6.0/go.mod h1:3BpzKBy/shNhVucY/MWOyx10tF3SFh9QdLuxbVysPQM=
|
||||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
||||
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||
|
|
|
|||
23
main.go
23
main.go
|
|
@ -4,9 +4,7 @@ import (
|
|||
"echoTest/controllers"
|
||||
"echoTest/models"
|
||||
"echoTest/utils"
|
||||
|
||||
"github.com/labstack/echo/v4"
|
||||
"github.com/labstack/echo/v4/middleware"
|
||||
"net/http"
|
||||
)
|
||||
|
||||
var (
|
||||
|
|
@ -20,20 +18,19 @@ var (
|
|||
)
|
||||
|
||||
func main() {
|
||||
e := echo.New()
|
||||
e.Use(middleware.Logger())
|
||||
e.Use(middleware.Recover())
|
||||
|
||||
router := http.NewServeMux()
|
||||
controller := controllers.NewController(&bewertungen, &maxPunkte)
|
||||
|
||||
e.GET("/", controller.RenderBewertungenRoute)
|
||||
e.POST("/toggle/:id", controller.ToggleWertungRoute)
|
||||
e.POST("/add", controller.AddBewertungRoute)
|
||||
e.GET("/export", controller.ExportBewertungenRoute)
|
||||
e.GET("/end", controller.EndRoute)
|
||||
router.HandleFunc("GET /", controller.RenderBewertungenRoute)
|
||||
router.HandleFunc("POST /toggle/{id}", controller.ToggleWertungRoute)
|
||||
router.HandleFunc("POST /add", controller.AddBewertungRoute)
|
||||
router.HandleFunc("GET /export", controller.ExportBewertungenRoute)
|
||||
router.HandleFunc("GET /end", controller.EndRoute)
|
||||
|
||||
go func() {
|
||||
e.Logger.Fatal(e.Start(":3000"))
|
||||
if err := http.ListenAndServe(":3000", router); err != nil {
|
||||
panic(err)
|
||||
}
|
||||
}()
|
||||
|
||||
utils.OpenInBrowser("http://localhost:3000")
|
||||
|
|
|
|||
|
|
@ -3,10 +3,9 @@ package utils
|
|||
import (
|
||||
"echoTest/models"
|
||||
"fmt"
|
||||
"net/http"
|
||||
"os/exec"
|
||||
"runtime"
|
||||
|
||||
"github.com/labstack/echo/v4"
|
||||
)
|
||||
|
||||
func SetNote(prozent float64) float64 {
|
||||
|
|
@ -51,7 +50,7 @@ func OpenInBrowser(url string) {
|
|||
}
|
||||
}
|
||||
|
||||
func ValidateName(c echo.Context, bewertungen *[]models.Bewertung) string {
|
||||
func ValidateName(c *http.Request, bewertungen *[]models.Bewertung) string {
|
||||
newNachname := c.FormValue("nachname")
|
||||
newVorname := c.FormValue("vorname")
|
||||
for _, bewertung := range *bewertungen {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue