123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485 |
- package data
- import (
- "eta/eta_api/models"
- "eta/eta_api/utils"
- "fmt"
- "strconv"
- "strings"
- "time"
- )
- func CommonClassifyMove(req models.CommonClassifyMoveReq, strategy CommonClassifyStrategy) (tips string, err error) {
- ctx := NewCommonClassifyCtx(strategy)
- var (
- classify *models.CommonClassify
- parentClassify *models.CommonClassify
- prevClassify *models.CommonClassify
- nextClassify *models.CommonClassify
- object *models.CommonClassifyObj
- prevObject *models.CommonClassifyObj
- nextObject *models.CommonClassifyObj
- sortPrev int
- sortNext int
- )
-
- if req.ParentClassifyId > 0 {
- c, e := ctx.GetCommonClassifyById(req.ParentClassifyId)
- if e != nil {
- err = fmt.Errorf("获取上级分类失败, %v", e)
- return
- }
- parentClassify = c
- }
-
- if req.PrevClassifyId > 0 {
- c, e := ctx.GetCommonClassifyById(req.PrevClassifyId)
- if e != nil {
- if e.Error() == utils.ErrNoRow() {
- tips = "上一个分类不存在, 请刷新页面"
- return
- }
- err = fmt.Errorf("获取上一个分类失败, %v", e)
- return
- }
- prevClassify = c
- sortPrev = prevClassify.Sort
- } else if req.PrevObjectId > 0 {
- obj, e := ctx.GetObjectById(req.PrevObjectId)
- if e != nil {
- if e.Error() == utils.ErrNoRow() {
- tips = "上一个移动对象不存在, 请刷新页面"
- return
- }
- err = fmt.Errorf("获取上一个移动对象失败, %v", e)
- return
- }
- prevObject = obj
- sortPrev = prevObject.Sort
- }
- if req.NextClassifyId > 0 {
- c, e := ctx.GetCommonClassifyById(req.NextClassifyId)
- if e != nil {
- if e.Error() == utils.ErrNoRow() {
- tips = "下一个分类不存在, 请刷新页面"
- return
- }
- err = fmt.Errorf("获取下一个分类失败, %v", e)
- return
- }
- nextClassify = c
- sortNext = nextClassify.Sort
- } else if req.NextObjectId > 0 {
- obj, e := ctx.GetObjectById(req.NextObjectId)
- if e != nil {
- if e.Error() == utils.ErrNoRow() {
- tips = "下一个移动对象不存在, 请刷新页面"
- return
- }
- err = fmt.Errorf("获取下一个移动对象失败, %v", e)
- return
- }
- nextObject = obj
- sortNext = nextObject.Sort
- }
-
- if req.ObjectId == 0 {
- c, e := ctx.GetCommonClassifyById(req.ClassifyId)
- if e != nil {
- if e.Error() == utils.ErrNoRow() {
- tips = "当前分类不存在, 请刷新页面"
- return
- }
- err = fmt.Errorf("获取当前分类失败, %v", e)
- return
- }
- classify = c
- return moveCommonClassify(ctx, req, classify, parentClassify, prevClassify, nextClassify, prevObject, nextObject, sortPrev, sortNext)
- }
-
- if req.ObjectId > 0 {
- obj, e := ctx.GetObjectById(req.ObjectId)
- if e != nil {
- if e.Error() == utils.ErrNoRow() {
- tips = "移动对象不存在, 请刷新页面"
- return
- }
- err = fmt.Errorf("获取移动对象失败, %v", e)
- return
- }
- if req.ParentClassifyId <= 0 {
- tips = "移动对象必须挂在分类下"
- return
- }
- object = obj
-
- return moveCommonClassifyObj(ctx, req, prevClassify, nextClassify, object, prevObject, nextObject, sortPrev, sortNext)
- }
- return
- }
- func moveCommonClassify(ctx *CommonClassifyCtx, req models.CommonClassifyMoveReq, classify, parentClassify, prevClassify, nextClassify *models.CommonClassify, prevObject, nextObject *models.CommonClassifyObj, sortPrev, sortNext int) (tips string, err error) {
-
- if req.ParentClassifyId > 0 && parentClassify.Level == 6 {
- tips = "最高只支持添加6级分类"
- return
- }
- exists, e := ctx.GetClassifyByParentIdAndName(req.ParentClassifyId, classify.ClassifyName, classify.ClassifyId)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = fmt.Errorf("获取父级分类下的同名分类失败, %v", e)
- return
- }
- if exists != nil {
- tips = "当前父级分类下存在相同名称"
- return
- }
-
- var classifyChildIds []int
- var classifyUpdateCols []string
- originParentId := classify.ParentId
- originLevel := classify.Level
-
- if originParentId != req.ParentClassifyId {
-
- levelPathArr := strings.Split(classify.LevelPath, ",")
- for _, p := range levelPathArr {
- d, _ := strconv.Atoi(p)
- if d > 0 {
- classifyChildIds = append(classifyChildIds, d)
- }
- }
- }
- colsMapping := ctx.GetCommonClassifyCols()
-
- if classify.ParentId != req.ParentClassifyId && req.ParentClassifyId != 0 {
- if classify.Level != parentClassify.Level+1 {
- tips = "不支持目录层级变更"
- return
- }
- classify.ParentId = parentClassify.ClassifyId
- classify.RootId = parentClassify.RootId
- classify.Level = parentClassify.Level + 1
- classify.ModifyTime = time.Now()
- classifyUpdateCols = append(classifyUpdateCols, colsMapping.ParentId, colsMapping.RootId, colsMapping.Level, colsMapping.ModifyTime)
- }
- if classify.ParentId != req.ParentClassifyId && req.ParentClassifyId == 0 {
- tips = "不支持目录层级变更"
- return
- }
- if sortPrev > 0 {
-
- if sortNext > 0 {
-
- if sortPrev == sortNext || sortPrev == classify.Sort {
- sortUpdate := `sort + 2`
- if prevClassify != nil {
- if e = ctx.SetClassifySortByParentId(req.ParentClassifyId, prevClassify.ClassifyId, prevClassify.Sort, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, prevClassify.ClassifyId, prevClassify.Sort, sortUpdate, e)
- return
- }
- } else {
- if e = ctx.SetClassifySortByParentId(req.ParentClassifyId, 0, sortPrev, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, sortPrev, sortUpdate, e)
- return
- }
- }
- if prevObject != nil {
- if e = ctx.SetObjectSortByClassifyId(req.ParentClassifyId, sortPrev, prevObject.ObjectId, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, sortPrev, prevObject.ObjectId, sortUpdate, e)
- return
- }
- } else {
- if e = ctx.SetObjectSortByClassifyId(req.ParentClassifyId, sortPrev, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, sortPrev, 0, sortUpdate, e)
- return
- }
- }
- } else {
-
- if sortNext-sortPrev == 1 {
- sortUpdate := `sort + 1`
- if prevClassify != nil {
- if e = ctx.SetClassifySortByParentId(req.ParentClassifyId, prevClassify.ClassifyId, sortPrev, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, prevClassify.ClassifyId, sortPrev, sortUpdate, e)
- return
- }
- } else {
- if e = ctx.SetClassifySortByParentId(req.ParentClassifyId, 0, sortPrev, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, sortPrev, sortUpdate, e)
- return
- }
- }
- if prevObject != nil {
- if e = ctx.SetObjectSortByClassifyId(req.ParentClassifyId, sortPrev, prevObject.ObjectId, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, sortPrev, prevObject.ObjectId, sortUpdate, e)
- return
- }
- } else {
- if e = ctx.SetObjectSortByClassifyId(req.ParentClassifyId, sortPrev, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, sortPrev, 0, sortUpdate, e)
- return
- }
- }
- }
- }
- }
- classify.Sort = sortPrev + 1
- classify.ModifyTime = time.Now()
- classifyUpdateCols = append(classifyUpdateCols, colsMapping.Sort, colsMapping.ModifyTime)
- } else if prevClassify == nil && nextClassify == nil && prevObject == nil && nextObject == nil && req.ParentClassifyId > 0 {
-
- m, e := GetCommonClassifySortMaxByParentId(req.ParentClassifyId, ctx)
- if e != nil {
- err = fmt.Errorf("GetCommonClassifySortMaxByParentId, %v", e)
- return
- }
- classify.Sort = m + 1
- classify.ModifyTime = time.Now()
- classifyUpdateCols = append(classifyUpdateCols, colsMapping.Sort, colsMapping.ModifyTime)
- } else {
-
- firstClassify, e := ctx.GetFirstClassifyByParentId(req.ParentClassifyId)
- if e != nil && e.Error() != utils.ErrNoRow() {
-
- err = fmt.Errorf("GetFirstClassifyByParentId, %v", e)
- return
- }
-
- if firstClassify != nil && firstClassify.Sort == 0 {
- sortUpdate := ` sort + 1 `
- if e = ctx.SetClassifySortByParentId(req.ParentClassifyId, firstClassify.ClassifyId-1, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, firstClassify.ClassifyId-1, 0, sortUpdate, e)
- return
- }
-
- if e = ctx.SetObjectSortByClassifyId(req.ParentClassifyId, 0, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, 0, sortUpdate, e)
- return
- }
- } else {
-
- firstObject, e := ctx.GetFirstObjectByClassifyId(req.ParentClassifyId)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = fmt.Errorf("GetFirstObjectByClassifyId, %v", e)
- return
- }
-
- if firstObject != nil && firstObject.Sort == 0 {
- sortUpdate := ` sort + 1 `
- if e = ctx.SetObjectSortByClassifyId(req.ParentClassifyId, 0, firstObject.ObjectId-1, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, firstObject.ObjectId-1, sortUpdate, e)
- return
- }
- if e = ctx.SetClassifySortByParentId(req.ParentClassifyId, 0, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, 0, sortUpdate, e)
- return
- }
- }
- }
- classify.Sort = 0
- classify.ModifyTime = time.Now()
- classifyUpdateCols = append(classifyUpdateCols, colsMapping.Sort, colsMapping.ModifyTime)
- }
-
- if len(classifyUpdateCols) > 0 {
- if e = ctx.UpdateCommonClassify(classify, classifyUpdateCols); e != nil {
- err = fmt.Errorf("UpdateCommonClassify, %v", e)
- return
- }
-
- if originParentId != req.ParentClassifyId {
- if len(classifyChildIds) > 0 {
- stepLevel := classify.Level - originLevel
- if e = ctx.UpdateClassifyChildByParentId(classifyChildIds, classify.RootId, stepLevel); e != nil {
- err = fmt.Errorf("UpdateClassifyChildByParentId, parentId: %d, classifyId: %d, stepLevel: %d, err: %v", req.ParentClassifyId, classify.ClassifyId, stepLevel, e)
- return
- }
- }
- }
- }
- return
- }
- func moveCommonClassifyObj(ctx *CommonClassifyCtx, req models.CommonClassifyMoveReq, prevClassify, nextClassify *models.CommonClassify, object, prevObject, nextObject *models.CommonClassifyObj, sortPrev, sortNext int) (tips string, err error) {
- var objUpdateCols []string
- colsMapping := ctx.GetCommonClassifyObjCols()
-
- if object.ClassifyId != req.ParentClassifyId {
- object.ClassifyId = req.ParentClassifyId
- object.ModifyTime = time.Now()
- objUpdateCols = append(objUpdateCols, colsMapping.ClassifyId, colsMapping.ModifyTime)
- }
- if sortPrev > 0 {
-
- if sortNext > 0 {
-
- if sortPrev == sortNext || sortPrev == object.Sort {
- sortUpdate := `sort + 2`
- if prevClassify != nil {
- if e := ctx.SetClassifySortByParentId(req.ParentClassifyId, prevClassify.ClassifyId, prevClassify.Sort, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, prevClassify.ClassifyId, prevClassify.Sort, sortUpdate, e)
- return
- }
- } else {
- if e := ctx.SetClassifySortByParentId(req.ParentClassifyId, 0, sortPrev, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, sortPrev, sortUpdate, e)
- return
- }
- }
- if prevObject != nil {
- if e := ctx.SetObjectSortByClassifyId(req.ParentClassifyId, sortPrev, prevObject.ObjectId, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, sortPrev, prevObject.ObjectId, sortUpdate, e)
- return
- }
- } else {
- if e := ctx.SetObjectSortByClassifyId(req.ParentClassifyId, sortPrev, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, sortPrev, 0, sortUpdate, e)
- return
- }
- }
- } else {
-
- if sortNext-sortPrev == 1 {
- sortUpdate := `sort + 1`
- if prevClassify != nil {
- if e := ctx.SetClassifySortByParentId(req.ParentClassifyId, prevClassify.ClassifyId, sortPrev, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, prevClassify.ClassifyId, sortPrev, sortUpdate, e)
- return
- }
- } else {
- if e := ctx.SetClassifySortByParentId(req.ParentClassifyId, 0, sortPrev, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, sortPrev, sortUpdate, e)
- return
- }
- }
- if prevObject != nil {
- if e := ctx.SetObjectSortByClassifyId(req.ParentClassifyId, sortPrev, prevObject.ObjectId, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, sortPrev, prevObject.ObjectId, sortUpdate, e)
- return
- }
- } else {
- if e := ctx.SetObjectSortByClassifyId(req.ParentClassifyId, sortPrev, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, sortPrev, 0, sortUpdate, e)
- return
- }
- }
- }
- }
- }
- object.Sort = sortPrev + 1
- object.ModifyTime = time.Now()
- objUpdateCols = append(objUpdateCols, colsMapping.Sort, colsMapping.ModifyTime)
- } else if prevClassify == nil && nextClassify == nil && prevObject == nil && nextObject == nil && req.ParentClassifyId > 0 {
-
- m, e := GetCommonClassifySortMaxByParentId(req.ParentClassifyId, ctx)
- if e != nil {
- err = fmt.Errorf("GetCommonClassifySortMaxByParentId, %v", e)
- return
- }
- object.Sort = m + 1
- object.ModifyTime = time.Now()
- objUpdateCols = append(objUpdateCols, colsMapping.Sort, colsMapping.ModifyTime)
- } else {
-
- firstClassify, e := ctx.GetFirstClassifyByParentId(req.ParentClassifyId)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = fmt.Errorf("GetFirstClassifyByParentId, %v", e)
- return
- }
-
- if firstClassify != nil && firstClassify.Sort == 0 {
- sortUpdate := ` sort + 1 `
- if e = ctx.SetClassifySortByParentId(req.ParentClassifyId, firstClassify.ClassifyId-1, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, firstClassify.ClassifyId-1, 0, sortUpdate, e)
- return
- }
-
- if e = ctx.SetObjectSortByClassifyId(req.ParentClassifyId, 0, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, 0, sortUpdate, e)
- return
- }
- } else {
-
- firstObject, e := ctx.GetFirstObjectByClassifyId(req.ParentClassifyId)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = fmt.Errorf("GetFirstObjectByClassifyId, %v", e)
- return
- }
-
- if firstObject != nil && firstObject.Sort == 0 {
- sortUpdate := ` sort + 1 `
- if e = ctx.SetObjectSortByClassifyId(req.ParentClassifyId, 0, firstObject.ObjectId-1, sortUpdate); e != nil {
- err = fmt.Errorf("SetObjectSortByClassifyId, classifyId: %d, sort: %d, objectId: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, firstObject.ObjectId-1, sortUpdate, e)
- return
- }
- if e = ctx.SetClassifySortByParentId(req.ParentClassifyId, 0, 0, sortUpdate); e != nil {
- err = fmt.Errorf("SetClassifySortByParentId, parentId: %d, classifyId: %d, sort: %d, sortUpdate: %s, err: %v", req.ParentClassifyId, 0, 0, sortUpdate, e)
- return
- }
- }
- }
- object.Sort = 0
- object.ModifyTime = time.Now()
- objUpdateCols = append(objUpdateCols, colsMapping.Sort, colsMapping.ModifyTime)
- }
-
- if len(objUpdateCols) > 0 {
- if e := ctx.UpdateCommonClassifyObj(object, objUpdateCols); e != nil {
- err = fmt.Errorf("UpdateCommonClassifyObj, %v", e)
- return
- }
- }
- return
- }
- func GetCommonClassifySortMaxByParentId(parentId int, ctx *CommonClassifyCtx) (sortMax int, err error) {
-
- classifyMax, e := ctx.GetClassifySortMaxByParentId(parentId)
- if e != nil {
- err = fmt.Errorf("GetClassifySortMaxByParentId, %v", e)
- return
- }
- sortMax = classifyMax
- objectMax, e := ctx.GetObjectSortMaxByClassifyId(parentId)
- if e != nil {
- err = fmt.Errorf("GetObjectSortMaxByClassifyId, %v", e)
- return
- }
- if sortMax < objectMax {
- sortMax = objectMax
- }
- return
- }
|