259 lines
7.5 KiB
Go
259 lines
7.5 KiB
Go
package models
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
orm "go-admin/common/global"
|
|
"go-admin/logger"
|
|
)
|
|
|
|
type Store struct {
|
|
Model
|
|
|
|
Name string `json:"name"` // 门店名称
|
|
Img string `json:"img"` // 门面图
|
|
Tel string `json:"tel" gorm:"type:varchar(20)"` // 电话
|
|
Province string `json:"province" gorm:"type:varchar(100)"` // 省
|
|
City string `json:"city" gorm:"type:varchar(100)"` // 市
|
|
District string `json:"district" gorm:"type:varchar(100)"` // 区
|
|
Address string `json:"address" gorm:"type:varchar(100)"` // 详细地址
|
|
Longitude float64 `json:"longitude" gorm:"column:longitude"` // 经度
|
|
Latitude float64 `json:"latitude" gorm:"column:latitude"` // 纬度
|
|
IsOnline uint32 `json:"is_online"` // 在线
|
|
CooperativeBusinessId uint32 `json:"cooperative_business_id" gorm:"index"` // 合作商id
|
|
CooperativeName string `json:"cooperative_name"` // 合作商名称
|
|
//GameCardGoods
|
|
CooperativeAssistantMemberDeduct *CooperativeAssistantMemberDeduct `json:"cooperative_assistant_member_deduct" gorm:"-"`
|
|
}
|
|
|
|
func (*Store) TableName() string {
|
|
return "store"
|
|
}
|
|
|
|
type GetCooperativeStoreReq struct {
|
|
Name string `json:"name"`
|
|
CooperativeBusinessId uint32 `json:"cooperative_business_id"` // 合作商id
|
|
CooperativeName string `json:"cooperative_name"` // 合作商名称
|
|
//SysType uint32 `json:"sys_type"` // 1-管理系统 2-合作商系统
|
|
SysUid string `json:"sys_uid"`
|
|
Page int `json:"pageIndex"`
|
|
PageSize int `json:"pageSize"`
|
|
}
|
|
|
|
func (m *GetCooperativeStoreReq) List() ([]Store, int64, error) {
|
|
fmt.Println("store name:", m.Name)
|
|
stores := make([]Store, 0)
|
|
|
|
if m.CooperativeBusinessId == 0 {
|
|
var sysUser SysUser
|
|
err := orm.Eloquent.Table("sys_user").Where("user_id=?", m.SysUid).Find(&sysUser).Error
|
|
if err != nil {
|
|
logger.Error("sys user err:", logger.Field("err", err))
|
|
return stores, 0, err
|
|
}
|
|
m.CooperativeBusinessId = sysUser.CooperativeBusinessId
|
|
}
|
|
qs := orm.Eloquent.Table("store")
|
|
if m.Name != "" {
|
|
qs = qs.Where("name LIKE '%" + m.Name + "%'")
|
|
}
|
|
if m.CooperativeBusinessId != 0 {
|
|
qs = qs.Where("cooperative_business_id=?", m.CooperativeBusinessId)
|
|
}
|
|
if m.CooperativeName != "" {
|
|
qs = qs.Where("cooperative_name LIKE '%" + m.CooperativeName + "%'")
|
|
}
|
|
//if m.SysType == 2 && m.CooperativeBusinessId == 0 {
|
|
// logger.Error("cooperative business id err:")
|
|
// return stores, 0, errors.New("cooperative business id err")
|
|
//}
|
|
page := m.Page - 1
|
|
if page < 0 {
|
|
page = 0
|
|
}
|
|
if m.PageSize == 0 {
|
|
m.PageSize = 10
|
|
}
|
|
var count int64
|
|
err := qs.Count(&count).Error
|
|
if err != nil {
|
|
logger.Error("count err:", logger.Field("err", err))
|
|
return stores, count, err
|
|
}
|
|
err = qs.Order("id DESC").Offset(page * m.PageSize).Limit(m.PageSize).Find(&stores).Error
|
|
if err != nil && err != RecordNotFound {
|
|
logger.Errorf("err:", logger.Field("err", err))
|
|
return stores, count, err
|
|
}
|
|
stores = StoreListSetCooperativeAssistantMemberDeduct(stores)
|
|
return stores, count, nil
|
|
}
|
|
|
|
type GetStoreReq struct {
|
|
Name string `json:"name"`
|
|
CooperativeBusinessId uint32 `json:"cooperative_business_id"` // 合作商id
|
|
CooperativeName string `json:"cooperative_name"` // 合作商名称
|
|
SysType uint32 `json:"sys_type"` // 1-管理系统 2-合作商系统
|
|
SysUid string `json:"sys_uid"`
|
|
Page int `json:"pageIndex"`
|
|
PageSize int `json:"pageSize"`
|
|
}
|
|
|
|
func (m *GetStoreReq) List() ([]Store, int64, error) {
|
|
fmt.Println("store name:", m.Name)
|
|
stores := make([]Store, 0)
|
|
|
|
//if m.CooperativeBusinessId == 0 {
|
|
// var sysUser SysUser
|
|
// err := orm.Eloquent.Table("sys_user").Where("user_id=?", m.SysUid).Find(&sysUser).Error
|
|
// if err != nil {
|
|
// logger.Error("sys user err:",logger.Field("err",err))
|
|
// return stores, 0, err
|
|
// }
|
|
// m.CooperativeBusinessId = sysUser.CooperativeBusinessId
|
|
//}
|
|
qs := orm.Eloquent.Table("store")
|
|
if m.Name != "" {
|
|
qs = qs.Where("name LIKE '%" + m.Name + "%'")
|
|
}
|
|
if m.CooperativeBusinessId != 0 {
|
|
qs = qs.Where("cooperative_business_id=?", m.CooperativeBusinessId)
|
|
}
|
|
if m.CooperativeName != "" {
|
|
qs = qs.Where("cooperative_name LIKE '%" + m.CooperativeName + "%'")
|
|
}
|
|
if m.SysType == 2 && m.CooperativeBusinessId == 0 {
|
|
logger.Error("cooperative business id err:")
|
|
return stores, 0, errors.New("cooperative business id err")
|
|
}
|
|
page := m.Page - 1
|
|
if page < 0 {
|
|
page = 0
|
|
}
|
|
if m.PageSize == 0 {
|
|
m.PageSize = 10
|
|
}
|
|
var count int64
|
|
err := qs.Count(&count).Error
|
|
if err != nil {
|
|
logger.Error("count err:", logger.Field("err", err))
|
|
return stores, count, err
|
|
}
|
|
err = qs.Order("id DESC").Offset(page * m.PageSize).Limit(m.PageSize).Find(&stores).Error
|
|
if err != nil && err != RecordNotFound {
|
|
logger.Errorf("err:", logger.Field("err", err))
|
|
return stores, count, err
|
|
}
|
|
stores = StoreListSetCooperativeAssistantMemberDeduct(stores)
|
|
return stores, count, nil
|
|
}
|
|
|
|
func StoreListSetCooperativeAssistantMemberDeduct(list []Store) []Store {
|
|
ids := make([]uint32, 0, len(list))
|
|
for i, _ := range list {
|
|
ids = append(ids, list[i].ID)
|
|
}
|
|
|
|
memberDeductMap, err := GetCooperativeAssistantMemberDeductMap(ids)
|
|
if err != nil {
|
|
logger.Error("cooperative assistant member deduct map err:", logger.Field("err", err))
|
|
return list
|
|
}
|
|
for i, _ := range list {
|
|
v, ok := memberDeductMap[list[i].ID]
|
|
if ok {
|
|
list[i].CooperativeAssistantMemberDeduct = v
|
|
}
|
|
}
|
|
return list
|
|
}
|
|
|
|
func (m *Store) Add() error {
|
|
err := orm.Eloquent.Create(m).Error
|
|
if err != nil {
|
|
logger.Errorf("err:", logger.Field("err", err))
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *Store) Modify() error {
|
|
para := m.getModifyPara()
|
|
if len(para) > 0 {
|
|
err := orm.Eloquent.Table(m.TableName()).Unscoped().Where("id", m.ID).Updates(para).Error
|
|
if err != nil {
|
|
logger.Errorf("err:", logger.Field("err", err))
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *Store) getModifyPara() map[string]interface{} {
|
|
paraMap := make(map[string]interface{}, 0)
|
|
if m.Name != "" {
|
|
paraMap["name"] = m.Name
|
|
}
|
|
if m.Img != "" {
|
|
paraMap["img"] = m.Img
|
|
}
|
|
if m.Tel != "" {
|
|
paraMap["tel"] = m.Tel
|
|
}
|
|
if m.Province != "" {
|
|
paraMap["province"] = m.Province
|
|
}
|
|
if m.City != "" {
|
|
paraMap["city"] = m.City
|
|
}
|
|
if m.District != "" {
|
|
paraMap["district"] = m.District
|
|
}
|
|
if m.Address != "" {
|
|
paraMap["address"] = m.Address
|
|
}
|
|
if m.Longitude != 0 {
|
|
paraMap["longitude"] = m.Longitude
|
|
}
|
|
if m.Latitude != 0 {
|
|
paraMap["latitude"] = m.Latitude
|
|
}
|
|
|
|
return paraMap
|
|
}
|
|
|
|
func (m *Store) MDel(ids []uint32) error {
|
|
err := orm.Eloquent.Table(m.TableName()).Unscoped().Where("id in (?)", ids).Delete(m).Error
|
|
if err != nil {
|
|
logger.Errorf("err:", logger.Field("err", err))
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func GetStore(id uint32) (*Store, error) {
|
|
var store Store
|
|
err := orm.Eloquent.Table("store").Where("id=?", id).Find(&store).Error
|
|
if err != nil {
|
|
logger.Errorf("err:", logger.Field("err", err))
|
|
return &store, err
|
|
}
|
|
return &store, nil
|
|
}
|
|
|
|
func GetStoreIdsByCooperativeBusinessId(id uint32) ([]uint32, error) {
|
|
ids := make([]uint32, 0)
|
|
var stores []Store
|
|
err := orm.Eloquent.Table("store").Where("cooperative_business_id=?", id).Find(&stores).Error
|
|
if err != nil {
|
|
logger.Errorf("err:", logger.Field("err", err))
|
|
return ids, err
|
|
}
|
|
|
|
for i, _ := range stores {
|
|
ids = append(ids, stores[i].ID)
|
|
}
|
|
|
|
return ids, nil
|
|
}
|