2023-05-25 21:04:43 -04:00
|
|
|
package entity
|
|
|
|
|
|
|
|
import (
|
|
|
|
"npm/internal/database"
|
|
|
|
"npm/internal/model"
|
|
|
|
|
|
|
|
"gorm.io/gorm"
|
|
|
|
)
|
|
|
|
|
|
|
|
// ListResponse is the JSON response for users list
|
|
|
|
type ListResponse struct {
|
|
|
|
Total int64 `json:"total"`
|
|
|
|
Offset int `json:"offset"`
|
|
|
|
Limit int `json:"limit"`
|
|
|
|
Sort []model.Sort `json:"sort"`
|
|
|
|
Filter []model.Filter `json:"filter,omitempty"`
|
|
|
|
Items interface{} `json:"items,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// ListQueryBuilder is used to setup queries for lists
|
|
|
|
func ListQueryBuilder(
|
|
|
|
pageInfo *model.PageInfo,
|
|
|
|
filters []model.Filter,
|
2023-07-23 21:49:08 -04:00
|
|
|
filterMap map[string]model.FilterMapValue,
|
2023-05-25 21:04:43 -04:00
|
|
|
) *gorm.DB {
|
|
|
|
scopes := make([]func(*gorm.DB) *gorm.DB, 0)
|
2023-05-28 23:53:16 -04:00
|
|
|
scopes = append(scopes, ScopeFilters(filters, filterMap))
|
2023-05-25 21:04:43 -04:00
|
|
|
return database.GetDB().Scopes(scopes...)
|
|
|
|
}
|
2023-05-30 23:52:58 -04:00
|
|
|
|
|
|
|
// AddOrderToList is used after query above is used for counting
|
|
|
|
// Postgres in particular doesn't like count(*) when ordering at the same time
|
|
|
|
func AddOrderToList(
|
|
|
|
dbo *gorm.DB,
|
2023-07-26 22:38:35 -04:00
|
|
|
sort []model.Sort,
|
2023-05-30 23:52:58 -04:00
|
|
|
defaultSort model.Sort,
|
|
|
|
) *gorm.DB {
|
2023-07-26 22:38:35 -04:00
|
|
|
return dbo.Scopes(ScopeOrderBy(sort, defaultSort))
|
|
|
|
}
|
|
|
|
|
|
|
|
// AddOffsetLimitToList is used after query above is used for pagination
|
|
|
|
func AddOffsetLimitToList(
|
|
|
|
dbo *gorm.DB,
|
|
|
|
pageInfo *model.PageInfo,
|
|
|
|
) *gorm.DB {
|
|
|
|
return dbo.Scopes(ScopeOffsetLimit(pageInfo))
|
2023-05-30 23:52:58 -04:00
|
|
|
}
|