123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287 |
- package service
- import (
- "app.yhyue.com/moapp/jybase/common"
- "app.yhyue.com/moapp/jybase/encrypt"
- "fmt"
- IC "jyBXCore/rpc/init"
- "jyBXCore/rpc/type/bxcore"
- "strings"
- )
- const (
- TableEntnicheUser = "entniche_user" // 企业用户表
- TableParticipateUser = "participate_user" // 参标用户表
- PositionTypeEnt = 1 // 职位类型企业
- PositionTypePersonal = 0 // 职位类型个人
- ButtonValueParticipate = 0 // 参标按钮 显示值 0-参标
- ButtonValueParticipated = 1 // 按钮显示值 列表页面 1-已参标
- RoleEntManager = 1 // 企业管理员角色
- RoleDepartManager = 2 // 部门管理员角色
- BidTypeDirect = 1 // 直接投标
- BidTypeChanel = 2 // 渠道投标
- )
- type ParticipateBid struct {
- EntId int64
- EntUserId int64
- PositionType int64
- PositionId int64
- EntRoleId int64 // 角色
- }
- func NewParticipateBid(entId, entUserId, positionType, positionId int64) ParticipateBid {
- return ParticipateBid{
- EntId: entId,
- EntUserId: entUserId,
- PositionType: positionType,
- PositionId: positionId,
- }
- }
- // PersonalExistProject 个人版要展示的参标按钮 查询出已经参标的项目信息 用于后边格式化数据
- func (p *ParticipateBid) PersonalExistProject(projectId []string) map[string]struct{} {
- // 1. 查询出已经参标的
- var arg []string
- var value []interface{}
- value = append(value, p.PositionId)
- for i := 0; i < len(projectId); i++ {
- arg = append(arg, "?")
- value = append(value, projectId[i])
- }
- argStr := strings.Join(arg, ",")
- query := "select project_id from " + TableParticipateUser + " where position_id = ? and project_id in (%s) and state>=0"
- rs := IC.BaseMysql.SelectBySql(fmt.Sprintf(query, argStr), value...)
- existProjectSet := map[string]struct{}{}
- if rs != nil && len(*rs) > 0 { // 如果查到了 说明已经参标 这部分应该显示已参标
- // 处理成map
- for i := 0; i < len(*rs); i++ {
- existId := common.ObjToString((*rs)[i]["project_id"])
- existProjectSet[existId] = struct{}{}
- }
- }
- return existProjectSet
- }
- // ListPersonalFormat 列表页个人版 参标按钮 格式化数据
- func (p *ParticipateBid) ListPersonalFormat(existProjectSet map[string]struct{}, infoM map[string]string) []*bxcore.ShowInfo {
- // 处理成 要返回的返回数据
- var formatList []*bxcore.ShowInfo
- for k, v := range infoM {
- buttonValue := ButtonValueParticipate // 不存在应该显示参标
- if _, ok := existProjectSet[v]; ok { // 存在说明应该显示已参标
- buttonValue = ButtonValueParticipated
- }
- formatList = append(formatList, &bxcore.ShowInfo{
- Id: encrypt.EncodeArticleId2ByCheck(k),
- Value: int64(buttonValue),
- })
- }
- return formatList
- }
- // EntExistProject 企业版 查出来企业下已经参标的这个项目的以及参标人信息 用于后边格式化数据判断有没有自己
- func (p *ParticipateBid) EntExistProject(projectId []string) map[string]string {
- var arg []string
- var value []interface{}
- value = append(value, p.EntId)
- for i := 0; i < len(projectId); i++ {
- arg = append(arg, "?")
- value = append(value, projectId[i])
- }
- argStr := strings.Join(arg, ",")
- query := "select GROUP_CONCAT(ent_user_id) as personIds ,project_id from " + TableParticipateUser + " where ent_id=? and project_id in (%s) and state>=0 group by project_id "
- rs := IC.BaseMysql.SelectBySql(fmt.Sprintf(query, argStr), value...)
- existProjectMap := map[string]string{}
- if rs != nil && len(*rs) > 0 { // 如果查到了 说明这个项目公司里面已经参标 处理一下信息用于后边判断是否是自己参标
- // 处理成map
- for i := 0; i < len(*rs); i++ {
- existId := common.ObjToString((*rs)[i]["project_id"])
- personIds := common.ObjToString((*rs)[i]["personIds"])
- existProjectMap[existId] = personIds
- }
- }
- return existProjectMap
- }
- // ListEntFormat 企业版 列表页数据格式化
- func (p *ParticipateBid) ListEntFormat(existProjectMap, infoM map[string]string, isAllow bool) []*bxcore.ShowInfo {
- // 处理成 要返回的返回数据
- var formatList []*bxcore.ShowInfo
- for k, v := range infoM {
- buttonValue := ButtonValueParticipate // 不存在时-显示参标
- if userIds, ok := existProjectMap[v]; ok { // 存在时 说明项目在企业下已经参标 需要进一步判断
- // 判断已经存在的参标人中是否包含自己 包含时 显示成已参标
- if ContainId(userIds, common.InterfaceToStr(p.EntUserId)) {
- buttonValue = ButtonValueParticipated
- } else if isAllow { // 不包含自己时需要 进一步判断公司设置是否允许多人参标
- // 允许时显示成 参标
- buttonValue = ButtonValueParticipate
- } else { // 不允许时 跳过该条信息
- continue
- }
- }
- formatList = append(formatList, &bxcore.ShowInfo{
- Id: encrypt.EncodeArticleId2ByCheck(k),
- Value: int64(buttonValue),
- })
- }
- return formatList
- }
- // DetailEntFormat 企业版 详情页数据格式化 返回数据 参标按钮 终止参标按钮 转给同事按钮 参标人姓名
- func (p *ParticipateBid) DetailEntFormat(existProjectMap map[string]string, isValid, isAllow bool) (formatData *bxcore.ParticipateDetailInfo) {
- // 处理成 要返回的返回数据
- formatData = &bxcore.ParticipateDetailInfo{}
- if len(existProjectMap) == 0 && isValid {
- // 无参标人 展示参标按钮 其余按钮不显示
- formatData.ShowParticipate = true
- return
- }
- persons := ""
- for _, v := range existProjectMap { // 这是为了取参标人id信息 列表页是多条数据 详情页这里 map里面只会有一条数据
- persons = v
- break
- }
- // 参标人信息 处理成姓名
- nameRs := GetNameByUserIds(persons)
- if nameRs != nil && len(*nameRs) > 0 {
- formatData.UserName = common.ObjToString((*nameRs)[0]["name"])
- }
- if !isValid {
- return
- }
- // 如果是管理员 显示 终止参标按钮、转给同事按钮
- if p.EntRoleId == RoleEntManager || p.EntRoleId == RoleDepartManager {
- formatData.ShowStopParticipate = true
- formatData.ShowTransfer = true
- }
- // 如果包含自己 显示终止参标按钮
- if ContainId(persons, common.InterfaceToStr(p.EntUserId)) {
- formatData.ShowStopParticipate = true
- } else if isAllow { // 如果允许多人 显示参标按钮
- formatData.ShowParticipate = true
- }
- return
- }
- // DetailPersonalFormat 详情页个人版 按钮格式化数据
- func (p *ParticipateBid) DetailPersonalFormat(existProjectSet map[string]struct{}, isValid bool) (formatData *bxcore.ParticipateDetailInfo) {
- // 处理成 要返回的返回数据
- formatData = &bxcore.ParticipateDetailInfo{}
- if !isValid {
- return
- }
- // 存在在说明已经参标 显示终止参标
- if len(existProjectSet) > 0 {
- formatData.ShowStopParticipate = true
- } else {
- // 不存在则说明 未参标 参标按钮展示
- formatData.ShowParticipate = true
- }
- return
- }
- // HandlerProjectId 返回信息的映射集合,项目id列表
- func HandlerProjectId(projectInfos []map[string]interface{}, infoIds map[string]struct{}) (map[string]string, []string) {
- result := map[string]string{}
- projectIdList := []string{}
- // 记录infoid 和项目id 对应关系 用于最后处理返回的数据
- for i := 0; i < len(projectInfos); i++ {
- _id := common.ObjToString(projectInfos[i]["_id"])
- projectIdList = append(projectIdList, _id)
- list, b := projectInfos[i]["list"].([]interface{})
- if !b {
- continue
- }
- for j := 0; j < len(list); j++ {
- infoidMap := common.ObjToMap(list[j])
- if infoidMap == nil {
- continue
- }
- infoid := common.ObjToString((*infoidMap)["infoid"])
- if _, ok := infoIds[infoid]; ok && infoid != "" {
- result[infoid] = _id
- break
- }
- }
- }
- return result, projectIdList
- }
- // DecodeId 解密标讯id 返回一个信息id的列表 和 集合
- func DecodeId(ids string) (result []string, resultSet map[string]struct{}) {
- idList := strings.Split(ids, ",")
- resultSet = map[string]struct{}{}
- for i := 0; i < len(idList); i++ {
- decodeArray := encrypt.DecodeArticleId2ByCheck(idList[i])
- if len(decodeArray) == 1 && decodeArray[0] != "" {
- result = append(result, decodeArray[0])
- resultSet[decodeArray[0]] = struct{}{}
- }
- }
- return
- }
- // ContainId 用于判断给定的逗号分割的字符串中是否包含 目标的字符串
- func ContainId(ids string, objId string) bool {
- list := strings.Split(ids, ",")
- for i := 0; i < len(list); i++ {
- if list[i] == objId {
- return true
- }
- }
- return false
- }
- // GetNameByUserIds 获取用户名字符串
- // 参数:逗号分割的用户id "11,22,333..."
- // 返回: "张三,李四,王五..."
- func GetNameByUserIds(ids string) *[]map[string]interface{} {
- query := "select group_concat(name) as name from " + TableEntnicheUser + " where id in (" + ids + ") "
- fmt.Println(query)
- rs := IC.MainMysql.SelectBySql(query)
- return rs
- }
- /*
- 投标状态更新
- 1. 验证参标人
- 2. 更新 存操作记录
- */
- // 更新投标状态
- func (p *ParticipateBid) updateBidStatus() {
- // 更新
- // 存操作记录
- }
- // 处理操作记录
- //var (
- // BidTypeKey = map[string]interface{}{
- //
- // }
- // ParticipateBidContentKey = map[string]interface{}{
- // "bidType":map[string]interface{}{
- // "name":"投标类型",
- // "updateAction":"调整",
- // "valueType":2,
- // "valueMap":map[int]interface{}{
- // BidTypeDirect:"直接投标",
- // BidTypeChanel:"渠道投标",
- // },
- // },
- // "isWin":map[string]interface{}{
- // "name":map[int]string{
- // 1:
- // },
- //
- // },
- // }
- //)
|