Compare commits

..

4 Commits

Author SHA1 Message Date
7730257cce Merge branch 'main' into login 2023-10-25 20:19:43 +02:00
21607a5c48 Ordering 2023-10-25 20:18:35 +02:00
30fccde9e5 Pagination 2023-10-25 20:06:13 +02:00
0188f97e60 Merge branch 'login' 2023-10-25 19:54:34 +02:00
4 changed files with 55 additions and 6 deletions

View File

@ -0,0 +1,16 @@
package repository
const ORDERING_ASC = "asc"
const ORDERING_DESC = "desc"
type Ordering struct {
Field string
Direction string
}
func NewOrdering(field string, direction string) Ordering {
return Ordering{
Field: field,
Direction: direction,
}
}

View File

@ -5,8 +5,9 @@ type Pagination struct {
Page int
}
func (p *Pagination) New() *Pagination {
p.PageSize = 50
p.Page = 1
return p
func NewPagination() Pagination {
return Pagination{
PageSize: 50,
Page: 1,
}
}

View File

@ -1,6 +1,7 @@
package repository
import (
"fmt"
"iris-test/app/models"
"gorm.io/gorm"
@ -34,11 +35,36 @@ func applyFilter(db *gorm.DB, filter *UserFilter) *gorm.DB {
return query
}
func (repository *UsersRepository) List(filter *UserFilter) *[]models.User {
func applyPagination(db *gorm.DB, pagination *Pagination) *gorm.DB {
query := db
if pagination != nil {
query.Limit(pagination.PageSize)
query.Offset(pagination.PageSize * (pagination.Page - 1))
}
return query
}
func applyOrdering(db *gorm.DB, ordering *[]Ordering) *gorm.DB {
query := db
if ordering != nil {
for _, order := range *ordering {
query.Order(fmt.Sprintf("%s %s", order.Field, order.Direction))
}
}
return query
}
func (repository *UsersRepository) List(filter *UserFilter, pagination *Pagination, ordering *[]Ordering) *[]models.User {
var users []models.User
query := repository.db.Model(&models.User{})
query = applyFilter(query, filter)
query = applyOrdering(query, ordering)
query = applyPagination(query, pagination)
query.Find(&users)
return &users

View File

@ -12,7 +12,13 @@ func GetUsersPage(ctx iris.Context) {
userRepository := repository.Dao.UsersRepository
users := userRepository.List(&repository.UserFilter{})
pagination := repository.NewPagination()
ordering := []repository.Ordering{
repository.NewOrdering("first_name", repository.ORDERING_ASC),
repository.NewOrdering("last_name", repository.ORDERING_ASC),
}
users := userRepository.List(&repository.UserFilter{}, &pagination, &ordering)
ctx.ViewData("users", users)