(1)库存调拨、库存变动中商品都拆分为单条数据; (2)编辑商品资料时同步更新库存表和库存商品表的商品编号; (3)租卡相关接口添加权限校验,只能查询对应门店权限的数据;
135 lines
3.6 KiB
Go
135 lines
3.6 KiB
Go
package models
|
|
|
|
import (
|
|
"errors"
|
|
_ "time"
|
|
|
|
orm "go-admin/common/global"
|
|
"go-admin/tools"
|
|
)
|
|
|
|
type SysConfig struct {
|
|
ConfigId int `json:"configId" gorm:"primary_key;auto_increment;"` //编码
|
|
ConfigName string `json:"configName" gorm:"size:128;"` //参数名称
|
|
ConfigKey string `json:"configKey" gorm:"size:128;"` //参数键名
|
|
ConfigValue string `json:"configValue" gorm:"size:255;"` //参数键值
|
|
ConfigType string `json:"configType" gorm:"size:64;"` //是否系统内置
|
|
Remark string `json:"remark" gorm:"size:128;"` //备注
|
|
CreateBy string `json:"createBy" gorm:"size:128;"`
|
|
UpdateBy string `json:"updateBy" gorm:"size:128;"`
|
|
BaseModel
|
|
|
|
DataScope string `json:"dataScope" gorm:"-"`
|
|
Params string `json:"params" gorm:"-"`
|
|
}
|
|
|
|
func (SysConfig) TableName() string {
|
|
return "sys_config"
|
|
}
|
|
|
|
// Config 创建
|
|
func (e *SysConfig) Create() (SysConfig, error) {
|
|
var doc SysConfig
|
|
var i int64
|
|
orm.Eloquent.Table(e.TableName()).Where("config_name=? or config_key = ?", e.ConfigName, e.ConfigKey).Count(&i)
|
|
if i > 0 {
|
|
return doc, errors.New("参数名称或者参数键名已经存在!")
|
|
}
|
|
|
|
result := orm.Eloquent.Table(e.TableName()).Create(&e)
|
|
if result.Error != nil {
|
|
err := result.Error
|
|
return doc, err
|
|
}
|
|
doc = *e
|
|
return doc, nil
|
|
}
|
|
|
|
// 获取 Config
|
|
func (e *SysConfig) Get() (SysConfig, error) {
|
|
var doc SysConfig
|
|
|
|
table := orm.Eloquent.Table(e.TableName())
|
|
if e.ConfigId != 0 {
|
|
table = table.Where("config_id = ?", e.ConfigId)
|
|
}
|
|
|
|
if e.ConfigKey != "" {
|
|
table = table.Where("config_key = ?", e.ConfigKey)
|
|
}
|
|
|
|
if err := table.First(&doc).Error; err != nil {
|
|
return doc, err
|
|
}
|
|
return doc, nil
|
|
}
|
|
|
|
func (e *SysConfig) GetPage(pageSize int, pageIndex int) ([]SysConfig, int, error) {
|
|
var doc []SysConfig
|
|
|
|
table := orm.Eloquent.Table(e.TableName())
|
|
|
|
if e.ConfigName != "" {
|
|
table = table.Where("config_name = ?", e.ConfigName)
|
|
}
|
|
if e.ConfigKey != "" {
|
|
table = table.Where("config_key = ?", e.ConfigKey)
|
|
}
|
|
if e.ConfigType != "" {
|
|
table = table.Where("config_type = ?", e.ConfigType)
|
|
}
|
|
|
|
// 数据权限控制
|
|
dataPermission := new(DataPermission)
|
|
dataPermission.UserId, _ = tools.StringToInt(e.DataScope)
|
|
table, err := dataPermission.GetDataScope("sys_config", table)
|
|
if err != nil {
|
|
return nil, 0, err
|
|
}
|
|
var count int64
|
|
|
|
if err := table.Offset((pageIndex - 1) * pageSize).Limit(pageSize).Find(&doc).Offset(-1).Limit(-1).Count(&count).Error; err != nil {
|
|
return nil, 0, err
|
|
}
|
|
//table.Where("`deleted_at` IS NULL").Total(&count)
|
|
return doc, int(count), nil
|
|
}
|
|
|
|
func (e *SysConfig) Update(id int) (update SysConfig, err error) {
|
|
if err = orm.Eloquent.Table(e.TableName()).Where("config_id = ?", id).First(&update).Error; err != nil {
|
|
return
|
|
}
|
|
|
|
if e.ConfigName != "" && e.ConfigName != update.ConfigName {
|
|
return update, errors.New("参数名称不允许修改!")
|
|
}
|
|
|
|
if e.ConfigKey != "" && e.ConfigKey != update.ConfigKey {
|
|
return update, errors.New("参数键名不允许修改!")
|
|
}
|
|
|
|
//参数1:是要修改的数据
|
|
//参数2:是修改的数据
|
|
if err = orm.Eloquent.Table(e.TableName()).Model(&update).Updates(&e).Error; err != nil {
|
|
return
|
|
}
|
|
return
|
|
}
|
|
|
|
func (e *SysConfig) Delete() (success bool, err error) {
|
|
if err = orm.Eloquent.Table(e.TableName()).Where("config_id = ?", e.ConfigId).Delete(&SysConfig{}).Error; err != nil {
|
|
success = false
|
|
return
|
|
}
|
|
success = true
|
|
return
|
|
}
|
|
|
|
func (e *SysConfig) BatchDelete(id []int) (Result bool, err error) {
|
|
if err = orm.Eloquent.Table(e.TableName()).Where("config_id in (?)", id).Delete(&SysConfig{}).Error; err != nil {
|
|
return
|
|
}
|
|
Result = true
|
|
return
|
|
}
|