feat(api): update template

This commit is contained in:
Leons Aleksandrovs
2025-07-13 14:19:47 +03:00
parent 23f8cde5af
commit fa095def44
4 changed files with 63 additions and 7 deletions

View File

@@ -2,6 +2,7 @@ package template
import (
"backend/models/template"
"backend/utils"
"backend/utils/jwt"
res "backend/utils/responses"
"net/http"
@@ -124,7 +125,52 @@ func GetID(c *gin.Context) {
res.Success(c, gin.H{"template": templates[0]})
}
func Update(c *gin.Context) {
type PutData struct {
Name string `json:"name" validate:"required,min=1,max=50"`
Content string `json:"content" validate:"required,min=50"`
}
func Put(c *gin.Context) {
// Get request data, with id, and user
id, err := strconv.Atoi(c.Param("id"))
if err != nil {
res.Error(c, err.Error(), http.StatusBadRequest)
return
}
user, err := jwt.GetUser(c)
if err != nil {
res.NeedsToLogin(c)
return
}
var data PutData
if err := utils.BindAndValidate(&data, c); err != nil {
res.Error(c, err.Error(), http.StatusBadRequest)
return
}
// Check if template already exists
templates, err := template.Get("user_id = $1 AND id = $2", user.Id, id)
if err != nil {
res.Error(c, err.Error(), http.StatusInternalServerError)
return
}
// Check if template is found
if len(templates) == 0 {
res.Error(c, "Template not found", http.StatusNotFound)
return
}
// Update template
err = template.Update(id, data.Name, data.Content)
if err != nil {
res.Error(c, err.Error(), http.StatusInternalServerError)
return
}
res.Success(c, gin.H{"message": "Successfully updated template"})
}
func Delete(c *gin.Context) {

View File

@@ -72,3 +72,13 @@ func Get(where string, args ...any) ([]Template, error) {
return results, nil
}
func Update(id int, name string, template string) error {
ctx, cancel := context.WithTimeout(context.Background(), 3*time.Second)
defer cancel()
query := `UPDATE templates SET name = $1, template = $2 WHERE id = $3`
_, err := db.Pool.Exec(ctx, query, name, template, id)
return err
}

View File

@@ -26,9 +26,9 @@ func SetupRoutes() *gin.Engine {
// Template routes (REST FUCKING GOOOOO)
templates := auth.Group("/templates")
templates.GET("", template.Get)
templates.GET(":id", template.GetID)
templates.GET("/:id", template.GetID)
templates.POST("", template.Create)
// PUT (Edit)
templates.PUT("/:id", template.Put)
// DELETE (Delete)
// Cover letter routes

View File

@@ -14,7 +14,7 @@ export const Route = createFileRoute("/templates/edit/$templateId")({
});
const editSchema = z.object({
name: z.string().min(1, "Name is required"),
name: z.string().min(1, "Name is required").max(50, "Name is too long"),
content: z.string().min(50, "Template is too short"),
});
@@ -25,7 +25,7 @@ function RouteComponent() {
const template = useQuery({
queryKey: ["template", templateId],
queryFn: () => requests.get<{ template: Template }>(`/template/${templateId}`, {}),
queryFn: () => requests.get<{ template: Template }>(`/templates/${templateId}`, {}),
});
const templateState = renderQueryState({
query: template,
@@ -39,13 +39,13 @@ function RouteComponent() {
const edit = useAppForm({
defaultValues: {
name: template.data?.template.name || "",
content: template.data?.template.content || null,
content: template.data?.template.template || null,
},
validators: {
onBlur: editSchema,
},
onSubmit({ value }) {
requests.put(`/template/${templateId}`, {
requests.put(`/templates/${templateId}`, {
data: value,
before() {
loading[1](true);