mirror of
https://github.com/0xJacky/nginx-ui.git
synced 2025-05-11 02:15:48 +02:00
fix: sort order
This commit is contained in:
parent
b1e95d30f1
commit
0d140b41da
1 changed files with 16 additions and 18 deletions
|
@ -1,36 +1,34 @@
|
|||
package cosy
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"github.com/0xJacky/Nginx-UI/internal/logger"
|
||||
"gorm.io/gorm"
|
||||
"gorm.io/gorm/schema"
|
||||
"strings"
|
||||
"sync"
|
||||
)
|
||||
|
||||
func (c *Ctx[T]) SortOrder() func(db *gorm.DB) *gorm.DB {
|
||||
return func(db *gorm.DB) *gorm.DB {
|
||||
sort := c.ctx.DefaultQuery("order", "desc")
|
||||
if sort != "desc" && sort != "asc" {
|
||||
sort = "desc"
|
||||
order := c.ctx.DefaultQuery("order", "desc")
|
||||
if order != "desc" && order != "asc" {
|
||||
order = "desc"
|
||||
}
|
||||
|
||||
order := c.itemKey
|
||||
if value, ok := c.ctx.Get("order"); ok {
|
||||
// check if the order field is valid
|
||||
// todo: maybe we can use more generic way to check if the sort_by is valid
|
||||
sortBy := c.ctx.DefaultQuery("sort_by", c.itemKey)
|
||||
|
||||
s, _ := schema.Parse(c.Model, &sync.Map{}, schema.NamingStrategy{})
|
||||
if _, ok := s.FieldsByDBName[value.(string)]; ok {
|
||||
order = value.(string)
|
||||
} else {
|
||||
logger.Error("invalid order field:", order)
|
||||
}
|
||||
} else if value, ok := c.ctx.Get("sort_by"); ok {
|
||||
order = value.(string)
|
||||
if _, ok := s.FieldsByDBName[sortBy]; !ok && sortBy != c.itemKey {
|
||||
logger.Error("invalid order field:", sortBy)
|
||||
return db
|
||||
}
|
||||
|
||||
order = fmt.Sprintf("%s %s", order, sort)
|
||||
return db.Order(order)
|
||||
var sb strings.Builder
|
||||
sb.WriteString(sortBy)
|
||||
sb.WriteString(" ")
|
||||
sb.WriteString(order)
|
||||
|
||||
return db.Order(sb.String())
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue