| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- /**
- * @Author: zou.yingbin
- * @Create : 2021/1/14 11:44
- * @Modify : 2021/1/14 11:44
- */
- package models
- import (
- "fmt"
- "mtp2_if/db"
- "mtp2_if/mtpcache"
- "strconv"
- )
- //变更变记录
- type ErmcpOPLogModel struct {
- BIZTYPE int32 `json:"biztype" xorm:"'BIZTYPE'"` // 业务类型 - 1:套保计划 2:现货合同
- OPERATELOGTYPE int32 `json:"operatelogtype" xorm:"'OPERATELOGTYPE'"` // 操作流水类型
- RELATEDID string `json:"relatedid" xorm:"'RELATEDID'"` // 现货合同ID\套保计划
- LOGVALUE float64 `json:"logvalue" xorm:"'LOGVALUE'"` // 数值
- BEFOREVALUE float64 `json:"beforevalue" xorm:"'BEFOREVALUE'"` // 变更前
- AFTERVALUE float64 `json:"aftervalue" xorm:"'AFTERVALUE'"` // 变更后
- UPDATETIME string `json:"updatetime" xorm:"'UPDATETIME'"` // 更新时间
- APPLYID string `json:"applyid" xorm:"'APPLYID'"` // 操作人ID
- CONTRACTTYPE int32 `json:"contracttype" xorm:"'CONTRACTTYPE'"` // 现货合同类型 - 1:采购 -1:销售
- OPERATELOGTYPEDESC string `json:"operatelogtypedesc"` // 操作流水类型名称
- APPLYNAME string `json:"applyname"` // 操作人名称
- }
- func (r *ErmcpOPLogModel) decodeOperateLogType() {
- //1:点价价格 2:点价数量 3:结算量 4:其它费用 5:追加保证金 6溢短金额 7:调整金额 8:付款金额 9:收款金额 10:退款金额
- //11:收票金额 12:开票金额 13:提交审核(合同) 14:审核通过(合同) 15:审核拒绝(合同) 16:合同撤回 17:提交审核(计划)
- //18:审核通过(计划) 19:审核拒绝(计划) 20:计划撤回 21:正常完结(合同) 22:异常终止(合同) 23:退还保证金
- sDes := []string{"点价价格", "点价数量", "结算量", "其它费用", "追加保证金", "溢短金额", "调整金额", "付款金额", "收款金额", "退款金额",
- "收票金额", "开票金额", "提交审核(合同)", "审核通过(合同)", "审核拒绝(合同)", "合同撤回", "提交审核(计划)",
- "审核通过(计划)", "审核拒绝(计划)", "计划撤回", "正常完结(合同)", "异常终止(合同)", "退还保证金"}
- if r.OPERATELOGTYPE >= 1 && r.OPERATELOGTYPE <= 23 {
- r.OPERATELOGTYPEDESC = sDes[r.OPERATELOGTYPE-1]
- }
- }
- func (r *ErmcpOPLogModel) buildSql() string {
- str := "select BIZTYPE," +
- " OPERATELOGTYPE," +
- " RELATEDID," +
- " LOGVALUE," +
- " BEFOREVALUE," +
- " AFTERVALUE," +
- " to_char(UPDATETIME,'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
- " APPLYID," +
- " CONTRACTTYPE" +
- " from ermcp_contractoperatelog t" +
- " where t.relatedid=%v"
- return fmt.Sprintf(str, r.RELATEDID)
- }
- //从数据库中获取操作变更数据
- func (r *ErmcpOPLogModel) GetData() ([]ErmcpOPLogModel, error) {
- e := db.GetEngine()
- sData := make([]ErmcpOPLogModel, 0)
- if err := e.SQL(r.buildSql()).Find(&sData); err != nil {
- return nil, err
- }
- // 类型解析成中文,操作人id转换为名称
- for i := range sData {
- sData[i].decodeOperateLogType()
- if id, err := strconv.ParseInt(sData[i].APPLYID, 10, 64); err == nil {
- sData[i].APPLYNAME = mtpcache.GetUserNameByLoginId(id)
- }
- }
- return sData, nil
- }
|