|
@@ -9,6 +9,7 @@ import (
|
|
|
"eta/eta_mini_api/utils"
|
|
|
"fmt"
|
|
|
"strconv"
|
|
|
+ "strings"
|
|
|
"time"
|
|
|
)
|
|
|
|
|
@@ -268,52 +269,51 @@ func (this *UserAuthController) AddReportRecord() {
|
|
|
chartMap[permission.ChartPermissionId] = permission
|
|
|
}
|
|
|
curTime := time.Now()
|
|
|
- insertIds := make([]int64, 0)
|
|
|
- if len(req.RecordId) <= 0 {
|
|
|
+ var insertId int64
|
|
|
+ if req.RecordId == 0 {
|
|
|
// 如果不存在就新增一条记录
|
|
|
+ permission1Ids := make([]string, 0)
|
|
|
+ permission2Ids := make([]string, 0)
|
|
|
+ permissionNames := make([]string, 0)
|
|
|
for _, item := range items {
|
|
|
curPermission := chartMap[item.ChartPermissionId]
|
|
|
- userReadRecord := &models.UserReadRecord{
|
|
|
- UserId: user.UserId,
|
|
|
- ReportId: req.ReportId,
|
|
|
- ReportTitle: req.ReportTitle,
|
|
|
- ChartPermissionId1: chartMap[curPermission.ParentId].ChartPermissionId,
|
|
|
- ChartPermissionId2: curPermission.ChartPermissionId,
|
|
|
- ChartPermissionName: curPermission.PermissionName,
|
|
|
- ClassifyId1: req.ClassifyIdFirst,
|
|
|
- ClassifyName1: req.ClassifyNameFirst,
|
|
|
- ClassifyId2: req.ClassifyIdSecond,
|
|
|
- ClassifyName2: req.ClassifyNameSecond,
|
|
|
- AreaCode: user.AreaCode,
|
|
|
- Phone: user.Phone,
|
|
|
- Email: user.Email,
|
|
|
- RealName: user.RealName,
|
|
|
- CompanyName: user.Company,
|
|
|
- Timestamp: int(curTime.Unix()),
|
|
|
- CreateTime: curTime,
|
|
|
- }
|
|
|
- insertId, _ := userReadRecord.Insert()
|
|
|
- insertIds = append(insertIds, insertId)
|
|
|
+ permission1Ids = append(permission1Ids, strconv.Itoa(curPermission.ParentId))
|
|
|
+ permission2Ids = append(permission2Ids, strconv.Itoa(curPermission.ChartPermissionId))
|
|
|
+ permissionNames = append(permissionNames, curPermission.PermissionName)
|
|
|
+ }
|
|
|
+ permission1Ids = utils.Unique(permission1Ids)
|
|
|
+ permission2Ids = utils.Unique(permission2Ids)
|
|
|
+ permissionNames = utils.Unique(permissionNames)
|
|
|
+ userReadRecord := &models.UserReadRecord{
|
|
|
+ UserId: user.UserId,
|
|
|
+ ReportId: req.ReportId,
|
|
|
+ ReportTitle: req.ReportTitle,
|
|
|
+ ChartPermissionId1: strings.Join(permission1Ids, ","),
|
|
|
+ ChartPermissionId2: strings.Join(permission2Ids, ","),
|
|
|
+ ChartPermissionName: strings.Join(permissionNames, ","),
|
|
|
+ ClassifyId1: req.ClassifyIdFirst,
|
|
|
+ ClassifyName1: req.ClassifyNameFirst,
|
|
|
+ ClassifyId2: req.ClassifyIdSecond,
|
|
|
+ ClassifyName2: req.ClassifyNameSecond,
|
|
|
+ Timestamp: int(curTime.Unix()),
|
|
|
+ CreateTime: curTime,
|
|
|
}
|
|
|
+ insertId, _ = userReadRecord.Insert()
|
|
|
} else {
|
|
|
// 如果存在就计算停留时间
|
|
|
- recordIds := make([]string, 0)
|
|
|
- for _, v := range req.RecordId {
|
|
|
- recordIds = append(recordIds, strconv.Itoa(v))
|
|
|
- }
|
|
|
- userRecordList, err := models.GetUserReadRecordListByRcordIds(recordIds)
|
|
|
+ userRecord, err := models.GetUserReadRecordListById(req.RecordId)
|
|
|
if err != nil {
|
|
|
+ if err.Error() == utils.ErrNoRow() {
|
|
|
+ br.Msg = "更新阅读记录不存在"
|
|
|
+ return
|
|
|
+ }
|
|
|
br.Msg = "更新阅读记录失败"
|
|
|
br.ErrMsg = "更新阅读记录失败,Err:" + err.Error()
|
|
|
return
|
|
|
}
|
|
|
- if len(userRecordList) == 0 {
|
|
|
- br.Msg = "更新阅读记录不存在"
|
|
|
- return
|
|
|
- }
|
|
|
- stayTime := curTime.Unix() - int64(userRecordList[0].Timestamp)
|
|
|
+ stayTime := curTime.Unix() - int64(userRecord.Timestamp)
|
|
|
stayTimeStr := utils.SecondsToHMS(stayTime)
|
|
|
- err = models.UpdateUserReadRecordByRecordIds(recordIds, int(curTime.Unix()), int(stayTime), stayTimeStr)
|
|
|
+ err = models.UpdateUserReadRecordById(req.RecordId, int(curTime.Unix()), int(stayTime), stayTimeStr)
|
|
|
if err != nil {
|
|
|
br.Msg = "更新阅读记录失败"
|
|
|
br.ErrMsg = "更新阅读记录失败,Err:" + err.Error()
|
|
@@ -321,7 +321,7 @@ func (this *UserAuthController) AddReportRecord() {
|
|
|
}
|
|
|
}
|
|
|
resp := new(response.UserReadRecordResp)
|
|
|
- resp.RecordIds = insertIds
|
|
|
+ resp.RecordId = insertId
|
|
|
|
|
|
br.Msg = "添加阅读记录成功"
|
|
|
br.Ret = 200
|