ranges.go 2.1 KB
Newer Older
aaronchen2k2k's avatar
aaronchen2k2k 已提交
1 2 3 4
package serverRepo

import (
	"github.com/easysoft/zendata/src/model"
5
	constant "github.com/easysoft/zendata/src/utils/const"
aaronchen2k2k's avatar
aaronchen2k2k 已提交
6 7 8 9 10 11 12
	"github.com/jinzhu/gorm"
)

type RangesRepo struct {
	db *gorm.DB
}

13 14 15 16 17
func (r *RangesRepo) ListAll() (models []*model.ZdRanges) {
	r.db.Find(&models)
	return
}

18 19 20 21 22 23 24 25 26 27 28 29 30
func (r *RangesRepo) List(keywords string, page int) (models []*model.ZdRanges, total int, err error) {
	query := r.db.Select("id,title,folder,path").Order("id ASC")
	if keywords != "" {
		query = query.Where("title LIKE ?", "%"+keywords+"%")
	}
	if page > 0 {
		query = query.Offset((page-1) * constant.PageSize).Limit(constant.PageSize)
	}

	err = query.Find(&models).Error

	err = r.db.Model(&model.ZdRanges{}).Count(&total).Error

aaronchen2k2k's avatar
aaronchen2k2k 已提交
31 32 33 34 35 36 37 38
	return
}

func (r *RangesRepo) Get(id uint) (ranges model.ZdRanges, err error) {
	err = r.db.Where("id=?", id).First(&ranges).Error
	return
}

aaronchen2k2k's avatar
aaronchen2k2k 已提交
39 40 41 42 43
func (r *RangesRepo) Create(ranges *model.ZdRanges) (err error) {
	err = r.db.Create(ranges).Error
	return
}
func (r *RangesRepo) Update(ranges *model.ZdRanges) (err error) {
aaronchen2k2k's avatar
aaronchen2k2k 已提交
44
	err = r.db.Save(ranges).Error
aaronchen2k2k's avatar
aaronchen2k2k 已提交
45 46 47 48
	return
}

func (r *RangesRepo) Remove(id uint) (err error) {
aaronchen2k2k's avatar
aaronchen2k2k 已提交
49 50 51 52 53
	ranges := model.ZdRanges{}
	ranges.ID = id

	err = r.db.Delete(ranges).Error
	err = r.db.Where("rangesID = ?", id).Delete(&model.ZdRangesItem{}).Error
aaronchen2k2k's avatar
aaronchen2k2k 已提交
54 55 56 57

	return
}

aaronchen2k2k's avatar
aaronchen2k2k 已提交
58 59 60 61 62 63 64 65 66 67 68 69
func (r *RangesRepo) GetItems(rangesId int) (items []*model.ZdRangesItem, err error) {
	err = r.db.Where("rangesId=?", rangesId).Find(&items).Error
	return
}
func (r *RangesRepo) GetItem(itemId uint) (item model.ZdRangesItem, err error) {
	err = r.db.Where("id=?", itemId).First(&item).Error
	return
}
func (r *RangesRepo) SaveItem(item *model.ZdRangesItem) (err error) {
	err = r.db.Save(item).Error
	return
}
aaronchen2k2k's avatar
aaronchen2k2k 已提交
70 71 72 73 74 75
func (r *RangesRepo) RemoveItem(id uint) (err error) {
	item := model.ZdRangesItem{}
	item.ID = id
	err = r.db.Delete(item).Error
	return
}
aaronchen2k2k's avatar
aaronchen2k2k 已提交
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
func (r *RangesRepo) GetMaxOrder(rangesId int) (ord int) {
	var preChild model.ZdField
	err := r.db.
		Where("rangesID=?", rangesId).
		Order("ord DESC").Limit(1).
		First(&preChild).Error

	if err != nil {
		ord = 1
	}
	ord = preChild.Ord + 1

	return
}

aaronchen2k2k's avatar
aaronchen2k2k 已提交
91 92 93
func NewRangesRepo(db *gorm.DB) *RangesRepo {
	return &RangesRepo{db: db}
}