123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578 |
- package chart
- import (
- "github.com/gin-gonic/gin"
- "hongze/hongze_yb/controller/response"
- "hongze/hongze_yb/models/response/my_chart"
- chartInfoModel "hongze/hongze_yb/models/tables/chart_info"
- myChartModel "hongze/hongze_yb/models/tables/my_chart"
- "hongze/hongze_yb/models/tables/my_chart_classify"
- myChartClassifyMappingModel "hongze/hongze_yb/models/tables/my_chart_classify_mapping"
- myChartLogModel "hongze/hongze_yb/models/tables/my_chart_log"
- "hongze/hongze_yb/services/chart"
- "hongze/hongze_yb/services/user"
- "hongze/hongze_yb/utils"
- "io/ioutil"
- "strconv"
- "time"
- )
- func GetMyChartChassify(c *gin.Context) {
- userInfo := user.GetInfoByClaims(c)
- publicCondition := make(map[string]interface{})
- privateCondition := make(map[string]interface{})
- reqKeywords := c.DefaultQuery("Keywords", "")
- if reqKeywords != "" {
- publicCondition["my_chart_classify_name like"] = "%" + reqKeywords + "%"
- privateCondition["my_chart_classify_name like"] = "%" + reqKeywords + "%"
- }
- publicClassify, privateClassify, err := chart.GetUserChartClassifyListByCondition(userInfo, publicCondition, privateCondition)
- if err != nil {
- response.Fail("获取图表分类失败, Err:"+err.Error(), c)
- return
- }
- respData := &my_chart.MyChartClassifyListResp{
- PublicClassify: publicClassify,
- PrivateClassify: privateClassify,
- }
- response.OkData("获取成功", respData, c)
- }
- func GetMyChartList(c *gin.Context) {
- userInfo := user.GetInfoByClaims(c)
-
- var condition string
- var pars []interface{}
- reqKeywords := c.DefaultQuery("Keywords", "")
- reqClassifyId := c.DefaultQuery("ClassifyId", "")
-
- publicCondition := make(map[string]interface{})
- privateCondition := make(map[string]interface{})
- publicClassify, privateClassify, err := chart.GetUserChartClassifyListByCondition(userInfo, publicCondition, privateCondition)
- if err != nil {
- response.FailMsg("获取失败", "获取图表分类信息失败, Err:"+err.Error(), c)
- return
- }
- if reqClassifyId == "" && reqKeywords == "" {
-
- classifyId := 0
- if len(privateClassify) > 0 {
- classifyId = privateClassify[0].MyChartClassifyId
- } else {
- if len(publicClassify) > 0 {
- classifyId = publicClassify[0].MyChartClassifyId
- }
- }
- condition += " AND d.my_chart_classify_id = ?"
- pars = append(pars, classifyId)
- } else if reqKeywords != "" {
-
- condition += " AND b.chart_name LIKE ?"
- pars = append(pars, "%"+reqKeywords+"%")
-
- classifyIds := make([]int, 0)
- for i := 0; i < len(publicClassify); i++ {
- classifyIds = append(classifyIds, publicClassify[i].MyChartClassifyId)
- }
- for i := 0; i < len(privateClassify); i++ {
- classifyIds = append(classifyIds, privateClassify[i].MyChartClassifyId)
- }
- condition += " AND d.my_chart_classify_id IN (?)"
- pars = append(pars, classifyIds)
- } else {
-
- condition += " AND d.my_chart_classify_id = ?"
- pars = append(pars, reqClassifyId)
- }
-
- page, _ := strconv.Atoi(c.Query("Page"))
- limit, _ := strconv.Atoi(c.Query("Limit"))
- if page == 0 {
- page = 1
- }
- if limit == 0 {
- limit = 10
- }
- list, err := myChartModel.GetMyChartListByCondition(condition, pars, page, limit)
- if err != nil {
- response.FailMsg("获取失败", "获取图库列表失败, Err:"+err.Error(), c)
- return
- }
- response.OkData("获取成功", list, c)
- }
- func MoveMyChart(c *gin.Context) {
-
- var req myChartModel.MoveMyChartReq
- if c.ShouldBind(&req) != nil {
- response.Fail("参数异常", c)
- return
- }
- if req.MyChartId == 0 {
- response.Fail("图表ID有误", c)
- return
- }
- if req.MyChartClassifyId == 0 {
- response.Fail("图表分类ID有误", c)
- return
- }
-
- userInfo := user.GetInfoByClaims(c)
- ok, adminInfo, err := user.GetAdminByUserInfo(userInfo)
- if err != nil {
- response.Fail("操作人信息有误", c)
- return
- }
- if !ok {
- response.Fail("非内部人员无权进行操作", c)
- return
- }
- adminId := int(adminInfo.AdminID)
- myChassify, err := my_chart_classify.GetClassifyById(req.MyChartClassifyId)
- if err != nil {
- if err == utils.ErrNoRow {
- response.FailMsg("操作失败", "图表分类信息有误, Err:"+err.Error(), c)
- return
- }
- response.FailMsg("操作失败", "获取图表分类信息失败, Err:"+err.Error(), c)
- return
- }
- if myChassify.AdminID != adminId {
- response.Fail("无权移动该图表", c)
- return
- }
-
- step := float64(65536)
- var newSort float64
- if req.PrevMyChartId <= 0 {
- firstMapItem, err := myChartClassifyMappingModel.GetMyChartSort(adminId, req.MyChartClassifyId, 0)
- if err != nil {
- response.FailMsg("操作失败", "获取图表排序失败4001, Err:"+err.Error(), c)
- return
- }
- if firstMapItem.Sort <= 0 {
- firstSort := step / float64(2)
- err = myChartClassifyMappingModel.MyChartMove(firstSort, adminId, firstMapItem.MyChartId, firstMapItem.MyChartClassifyId)
- if err != nil {
- response.FailMsg("操作失败", "移动失败4001, Err:"+err.Error(), c)
- return
- }
- newSort = step / float64(4)
- } else {
- newSort = firstMapItem.Sort / float64(2)
- }
- } else if req.NextMyChartId <= 0 {
- latestMapItem, err := myChartClassifyMappingModel.GetMyChartSort(adminId, req.MyChartClassifyId, 1)
- if err != nil {
- response.FailMsg("操作失败", "获取图表排序失败4002, Err:"+err.Error(), c)
- return
- }
- if latestMapItem.Sort <= 0 {
- latestSort := step / float64(2)
- err = myChartClassifyMappingModel.MyChartMove(latestSort, adminId, latestMapItem.MyChartId, latestMapItem.MyChartClassifyId)
- if err != nil {
- response.FailMsg("操作失败", "移动失败4002, Err:"+err.Error(), c)
- return
- }
- newSort = step / float64(4)
- } else {
- newSort = latestMapItem.Sort + (step / float64(2)) - 1
- }
- } else {
- preMapItem, err := myChartClassifyMappingModel.GetMyChartClassifyMapping(adminId, req.PrevMyChartId, req.MyChartClassifyId)
- if err != nil {
- response.FailMsg("操作失败", "获取上级图表关联信息失败, Err:"+err.Error(), c)
- return
- }
- nextMapItem, err := myChartClassifyMappingModel.GetMyChartClassifyMapping(adminId, req.NextMyChartId, req.MyChartClassifyId)
- if err != nil {
- response.FailMsg("操作失败", "获取下级图表关联信息失败, Err:"+err.Error(), c)
- return
- }
- newSort = (preMapItem.Sort + nextMapItem.Sort) / 2
- }
- if newSort >= 0 {
- err = myChartClassifyMappingModel.MyChartMove(newSort, adminId, req.MyChartId, req.MyChartClassifyId)
- if err != nil {
- response.FailMsg("操作失败", "移动失败4003, Err:"+err.Error(), c)
- return
- }
- }
-
- {
- bodyBytes, _ := ioutil.ReadAll(c.Request.Body)
- requestBodyStr := string(bodyBytes)
- edbLog := new(myChartLogModel.MyChartLog)
- edbLog.MyChartId = 0
- edbLog.ChartInfoId = 0
- edbLog.SysUserId = adminId
- edbLog.SysUserRealName = adminInfo.RealName
- edbLog.CreateTime = time.Now()
- edbLog.Content = requestBodyStr
- edbLog.Status = "移动我的图表"
- edbLog.Method = c.Request.URL.String()
- go edbLog.Create()
- }
- response.Ok("操作成功", c)
- }
- func MoveMyChartClassify(c *gin.Context) {
-
- var req myChartModel.MoveMyChartClassifyReq
- if c.ShouldBind(&req) != nil {
- response.Fail("参数异常", c)
- return
- }
- if req.MyChartClassifyId == 0 {
- response.Fail("图表分类ID有误", c)
- return
- }
-
- userInfo := user.GetInfoByClaims(c)
- ok, adminInfo, err := user.GetAdminByUserInfo(userInfo)
- if err != nil {
- response.Fail("操作人信息有误", c)
- return
- }
- if !ok {
- response.Fail("非内部人员无权进行操作", c)
- return
- }
- adminId := int(adminInfo.AdminID)
- myChassify, err := my_chart_classify.GetClassifyById(req.MyChartClassifyId)
- if err != nil {
- if err == utils.ErrNoRow {
- response.FailMsg("操作失败", "该图表分类信息有误, Err:", c)
- return
- }
- response.FailMsg("操作失败", "获取图表信息失败"+err.Error(), c)
- return
- }
- if myChassify.AdminID != adminId {
- response.Fail("无权移动该图表", c)
- return
- }
-
- updateCol := make([]string, 0)
- if req.PrevClassifyId > 0 {
- prevClassify, err := my_chart_classify.GetClassifyByIdAndAdminId(adminId, req.PrevClassifyId)
- if err != nil {
- response.FailMsg("操作失败", "移动失败, 获取上一个兄弟节点分类信息失败, Err:"+err.Error(), c)
- return
- }
-
- if req.NextClassifyId > 0 {
-
- nextClassify, err := my_chart_classify.GetClassifyByIdAndAdminId(adminId, req.NextClassifyId)
- if err != nil {
- response.FailMsg("操作失败", "移动失败, 获取下一个兄弟节点分类信息失败, Err:"+err.Error(), c)
- return
- }
-
- if prevClassify.Sort == nextClassify.Sort || prevClassify.Sort == myChassify.Sort {
-
- updateSortStr := `sort + 2`
- _ = my_chart_classify.UpdateMyChartClassifySortByClassifyId(adminId, prevClassify.MyChartClassifyId, prevClassify.Sort, updateSortStr)
- } else {
-
- if nextClassify.Sort-prevClassify.Sort == 1 {
-
- updateSortStr := `sort + 1`
- _ = my_chart_classify.UpdateMyChartClassifySortByClassifyId(adminId, 0, prevClassify.Sort, updateSortStr)
- }
- }
- }
- myChassify.Sort = prevClassify.Sort + 1
- myChassify.ModifyTime = time.Now()
- updateCol = append(updateCol, "Sort", "ModifyTime")
- } else {
- firstClassify, err := my_chart_classify.GetFirstClassifyByAdminId(adminId)
- if err != nil && err != utils.ErrNoRow {
- response.FailMsg("操作失败", "移动失败, 获取获取当前账号下的排序第一条的分类信息失败, Err:"+err.Error(), c)
- return
- }
-
- if firstClassify != nil && firstClassify.Sort == 0 {
- updateSortStr := ` sort + 1 `
- _ = my_chart_classify.UpdateMyChartClassifySortByClassifyId(adminId, firstClassify.MyChartClassifyId-1, 0, updateSortStr)
- }
- myChassify.Sort = 0
- myChassify.ModifyTime = time.Now()
- updateCol = append(updateCol, "Sort", "ModifyTime")
- }
-
- if len(updateCol) > 0 {
- err = my_chart_classify.UpdateClassifySort(adminId, myChassify.MyChartClassifyId, myChassify.Sort, myChassify.ModifyTime)
- if err != nil {
- response.FailMsg("操作失败", "更新图表分类排序失败, Err:"+err.Error(), c)
- return
- }
- }
-
- {
- bodyBytes, _ := ioutil.ReadAll(c.Request.Body)
- requestBodyStr := string(bodyBytes)
- edbLog := new(myChartLogModel.MyChartLog)
- edbLog.MyChartId = 0
- edbLog.ChartInfoId = 0
- edbLog.SysUserId = adminId
- edbLog.SysUserRealName = adminInfo.RealName
- edbLog.CreateTime = time.Now()
- edbLog.Content = requestBodyStr
- edbLog.Status = "移动分类"
- edbLog.Method = c.Request.URL.String()
- go edbLog.Create()
- }
- response.Ok("操作成功", c)
- }
- func GetChartBeforeAndNext(c *gin.Context) {
-
- reqMyChartId := c.DefaultQuery("MyChartId", "")
- if reqMyChartId == "" {
- response.Fail("参数有误:图表ID", c)
- return
- }
- myChartId, _ := strconv.Atoi(reqMyChartId)
- myChartClassifyId := c.DefaultQuery("MyChartClassifyId", "")
- if myChartClassifyId == "" {
- response.Fail("参数有误:图表分类ID", c)
- return
- }
-
- myChartInfo, err := myChartModel.GetMyChartById(myChartId, myChartClassifyId)
- if err != nil {
- if err == utils.ErrNoRow {
- response.Fail("图表已被删除,请刷新当前页面", c)
- return
- }
- response.FailMsg("获取失败", "获取我的图表信息失败, Err:"+err.Error(), c)
- return
- }
-
- myChartList, err := myChartClassifyMappingModel.GetMyChartSortInfoList(myChartClassifyId, 2)
-
- var currentIndex int
- lastIndex := len(myChartList) - 1
- for index, item := range myChartList {
- if myChartInfo.MyChartId == item.MyChartId {
- currentIndex = index
- break
- }
- }
- var beforeChart, afterChart *myChartClassifyMappingModel.MyChartSortInfo
- beforeIndex := currentIndex - 1
- if beforeIndex >= 0 {
-
- beforeChart = myChartList[beforeIndex]
- }
- afterIndex := currentIndex + 1
- if afterIndex <= lastIndex {
-
- afterChart = myChartList[afterIndex]
- }
-
- if beforeIndex < 0 || afterIndex > lastIndex {
-
- userInfo := user.GetInfoByClaims(c)
- publicCondition := make(map[string]interface{})
- privateCondition := make(map[string]interface{})
- publicClassify, privateClassify, err := chart.GetUserChartClassifyListByCondition(userInfo, publicCondition, privateCondition)
- if err != nil {
- response.FailMsg("获取失败", "获取图表分类失败, Err:"+err.Error(), c)
- return
- }
-
- var classifyList []*my_chart_classify.MyChartClassify
- for i := 0; i < len(publicClassify); i++ {
- classifyList = append(classifyList, publicClassify[i])
- }
- for i := 0; i < len(privateClassify); i++ {
- classifyList = append(classifyList, privateClassify[i])
- }
-
- var currentClassifyIndex int
- for indexClassify, itemClassify := range classifyList {
- itemClassifyId := strconv.Itoa(itemClassify.MyChartClassifyId)
- if myChartClassifyId == itemClassifyId {
- currentClassifyIndex = indexClassify
- break
- }
- }
- lastClassifyIndex := len(classifyList) - 1
-
- beforeClassifyIndex := currentClassifyIndex - 1
- if beforeIndex < 0 && len(classifyList) > 0 && beforeClassifyIndex >= 0 {
- beforeClassifyIdStr := strconv.Itoa(classifyList[beforeClassifyIndex].MyChartClassifyId)
- beforeClassifyChartList, tempErr := myChartClassifyMappingModel.GetMyChartSortInfoList(beforeClassifyIdStr, 1)
- if tempErr != nil {
- response.FailMsg("获取失败", "获取上一个分类图表信息失败4101, Err:"+tempErr.Error(), c)
- return
- }
-
- SearchPrevChart:
- if len(beforeClassifyChartList) > 0 {
- beforeChart = beforeClassifyChartList[0]
- } else {
- beforeClassifyIndex -= 1
- if beforeClassifyIndex >= 0 {
- beforeClassifyIdStr = strconv.Itoa(classifyList[beforeClassifyIndex].MyChartClassifyId)
- beforeClassifyChartList, tempErr = myChartClassifyMappingModel.GetMyChartSortInfoList(beforeClassifyIdStr, 1)
- if tempErr != nil {
- response.FailMsg("获取失败", "获取上一个分类图表信息失败4102, Err:"+tempErr.Error(), c)
- return
- }
- goto SearchPrevChart
- }
- }
- }
-
- afterClassifyIndex := currentClassifyIndex + 1
- if afterIndex > lastIndex && len(classifyList) > 0 && afterClassifyIndex <= lastClassifyIndex {
- afterClassifyIdStr := strconv.Itoa(classifyList[afterClassifyIndex].MyChartClassifyId)
- afterClassifyChartList, tempErr := myChartClassifyMappingModel.GetMyChartSortInfoList(afterClassifyIdStr, 2)
- if tempErr != nil {
- response.FailMsg("获取失败", "获取下一个分类图表信息失败4103, Err:"+tempErr.Error(), c)
- return
- }
-
- SearchNextChart:
- if len(afterClassifyChartList) > 0 {
- afterChart = afterClassifyChartList[0]
- } else {
- afterClassifyIndex += 1
- if afterClassifyIndex <= lastClassifyIndex {
- afterClassifyIdStr = strconv.Itoa(classifyList[afterClassifyIndex].MyChartClassifyId)
- afterClassifyChartList, tempErr = myChartClassifyMappingModel.GetMyChartSortInfoList(afterClassifyIdStr, 2)
- if tempErr != nil {
- response.FailMsg("获取失败", "获取下一个分类图表信息失败4104, Err:"+tempErr.Error(), c)
- return
- }
- goto SearchNextChart
- }
- }
- }
- }
- var beforeResp, afterResp chartInfoModel.ChartSortInfo
- if beforeChart != nil {
- beforeResp.MyChartId = beforeChart.MyChartId
- beforeResp.MyChartClassifyId = beforeChart.MyChartClassifyId
- beforeResp.MyChartClassifyName = beforeChart.MyChartClassifyName
- beforeResp.Sort = int(beforeChart.Sort)
- beforeResp.UniqueCode = beforeChart.UniqueCode
- beforeResp.ChartInfoId = beforeChart.ChartInfoId
- beforeResp.ChartInfoSource = beforeChart.ChartInfoSource
- if beforeIndex < 0 {
- beforeResp.Switch = 1
- }
- }
- if afterChart != nil {
- afterResp.MyChartId = afterChart.MyChartId
- afterResp.MyChartClassifyId = afterChart.MyChartClassifyId
- afterResp.MyChartClassifyName = afterChart.MyChartClassifyName
- afterResp.Sort = int(afterChart.Sort)
- afterResp.UniqueCode = afterChart.UniqueCode
- afterResp.ChartInfoId = afterChart.ChartInfoId
- afterResp.ChartInfoSource = afterChart.ChartInfoSource
- if afterIndex > lastIndex {
- afterResp.Switch = 1
- }
- }
- resp := chartInfoModel.ChartBeforeNext{
- PrevChart: beforeResp,
- NextChart: afterResp,
- }
- response.OkData("获取成功", resp, c)
- }
|