wp-go/internal/dao/common.go

56 lines
1.4 KiB
Go
Raw Normal View History

2023-01-12 12:42:16 +00:00
package common
import (
"context"
"fmt"
2023-01-13 06:04:32 +00:00
models2 "github/fthvgb1/wp-go/internal/pkg/models"
2023-01-12 12:42:16 +00:00
"github/fthvgb1/wp-go/internal/wpconfig"
"github/fthvgb1/wp-go/model"
)
var TotalRaw int64
type PostIds struct {
Ids []uint64
Length int
}
type PostContext struct {
2023-01-13 06:04:32 +00:00
Prev models2.Posts
Next models2.Posts
2023-01-12 12:42:16 +00:00
}
2023-01-13 06:04:32 +00:00
func PasswordProjectTitle(post *models2.Posts) {
2023-01-12 12:42:16 +00:00
if post.PostPassword != "" {
post.PostTitle = fmt.Sprintf("密码保护:%s", post.PostTitle)
}
}
2023-01-13 06:04:32 +00:00
func Categories(a ...any) (terms []models2.TermsMy, err error) {
2023-01-12 12:42:16 +00:00
ctx := a[0].(context.Context)
var in = []any{"category"}
2023-01-13 06:04:32 +00:00
terms, err = model.Find[models2.TermsMy](ctx, model.SqlBuilder{
2023-01-12 12:42:16 +00:00
{"tt.count", ">", "0", "int"},
{"tt.taxonomy", "in", ""},
}, "t.term_id", "", model.SqlBuilder{
{"t.name", "asc"},
}, model.SqlBuilder{
{"t", "inner join", "wp_term_taxonomy tt", "t.term_id = tt.term_id"},
}, nil, 0, in)
for i := 0; i < len(terms); i++ {
if v, ok := wpconfig.Terms.Load(terms[i].Terms.TermId); ok {
terms[i].Terms = v
}
if v, ok := wpconfig.TermTaxonomies.Load(terms[i].Terms.TermId); ok {
terms[i].TermTaxonomy = v
}
}
return
}
2023-01-13 06:04:32 +00:00
func Archives(ctx context.Context) ([]models2.PostArchive, error) {
return model.Find[models2.PostArchive](ctx, model.SqlBuilder{
2023-01-12 12:42:16 +00:00
{"post_type", "post"}, {"post_status", "publish"},
}, "YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, count(ID) as posts", "year,month", model.SqlBuilder{{"year", "desc"}, {"month", "desc"}}, nil, nil, 0)
}