Compare commits
merge into: donghanyang:master
donghanyang:client_ljk
donghanyang:details_ljk
donghanyang:dev
donghanyang:dev_ljk
donghanyang:dhy
donghanyang:lijikun
donghanyang:majun
donghanyang:master
pull from: donghanyang:details_ljk
donghanyang:client_ljk
donghanyang:details_ljk
donghanyang:dev
donghanyang:dev_ljk
donghanyang:dhy
donghanyang:lijikun
donghanyang:majun
donghanyang:master
6 Commits
master
...
details_lj
Author | SHA1 | Message | Date |
---|---|---|---|
|
162073cf85 |
12月18日 导出excel尝试
|
5 months ago |
|
5b963fdb5d |
12月18日调整logic层与service层名字,功能未变动,删除不属于这个分支的文件
|
5 months ago |
|
0d3c157f2e |
12月17日完成后台查看明细页面所有接口
|
5 months ago |
|
642d8cac46 |
12月12日代码编写,后台获取明细请求体,响应体
|
5 months ago |
|
55fb5a16ef |
12月12日代码编写,对客户端主页查询接口进行修改完善(函数名,提交次数),完成作业题目查询
|
5 months ago |
|
940d3bfcab |
12月11日客户端首页查询接口编写(未从token获取jwcode)
|
5 months ago |
19 changed files with 693 additions and 162 deletions
-
1link_homework/api/v1/hello.go
-
68link_homework/api/v1/record/Record.go
-
15link_homework/go.mod
-
90link_homework/go.sum
-
2link_homework/hack/config.yaml
-
46link_homework/internal/cmd/cmd.go
-
1link_homework/internal/controller/clientPage/clientPage.go
-
269link_homework/internal/controller/record/manageRecord.go
-
24link_homework/internal/dao/internal/activity_interactive_form.go
-
24link_homework/internal/dao/internal/activity_interactive_group.go
-
24link_homework/internal/dao/internal/activity_interactive_record.go
-
22link_homework/internal/dao/internal/fx_article.go
-
24link_homework/internal/dao/internal/live.go
-
22link_homework/internal/dao/internal/member_info.go
-
4link_homework/internal/logic/logic.go
-
148link_homework/internal/logic/record/record.go
-
24link_homework/internal/model/dto/ToolStruct.go
-
8link_homework/internal/service/middleware.go
-
39link_homework/internal/service/record.go
@ -1 +0,0 @@ |
|||
package v1 |
@ -0,0 +1,68 @@ |
|||
package record |
|||
|
|||
import ( |
|||
"github.com/gogf/gf/v2/os/gtime" |
|||
"link_homework/internal/model/dto" |
|||
) |
|||
|
|||
type GetRecordListReq struct { |
|||
Id int `json:"id" orm:"" dc:"作业id"` |
|||
PageNo int `json:"pageNo" dc:"当前页"` |
|||
PageSize int `json:"pageSize" dc:"每页条数"` |
|||
} |
|||
|
|||
// 合并并返回的提交详情所用信息
|
|||
type GetRecordListRes struct { |
|||
Total int `json:"total" dc:"总条数"` |
|||
Jwcode int `json:"jwcode" orm:"db:cms;table:member_info;column:jwcode" dc:"精网号"` |
|||
Name string `json:"name" orm:"db:cms;table:member_info;column:name" dc:"用户名字"` |
|||
DeptId string `json:"deptId" orm:"db:cms;table:member_info;column:deptId" dc:"部门id"` |
|||
DeptName string `json:"deptName" orm:"db:cms;member_info;column:deptName" dc:"部门名"` |
|||
ShopId string `json:"shopId" orm:"db:cms;member_info;column:shopId" dc:"门店id"` |
|||
ShopName string `json:"shopName" orm:"db:cms;member_info;column:shopName" dc:"门店名"` |
|||
Reply []dto.RecordInfo |
|||
} |
|||
|
|||
type GetRecordByConditionReq struct { |
|||
Id int `json:"id" orm:"" dc:"作业id"` |
|||
Jwcode int `json:"jwcode" dc:"精网号"` |
|||
DeptId string `json:"deptId" dc:"部门id"` |
|||
ShopId string `json:"shopId" dc:"门店id"` |
|||
PageNo int `json:"pageNo" dc:"当前页"` |
|||
PageSize int `json:"pageSize" dc:"每页条数"` |
|||
} |
|||
|
|||
/*GetRecordByConditionRes的返回值与GetRecordListRes的一致,所以直接套用*/ |
|||
|
|||
type GetDeptInfoRes struct { |
|||
DeptId string `json:"deptId" orm:"db:cms;table:member_info;column:deptId" dc:"部门id"` |
|||
DeptName string `json:"deptName" orm:"db:cms;member_info;column:deptName" dc:"部门名"` |
|||
} |
|||
|
|||
type GetShopInfoByDeptIdReq struct { |
|||
DeptId string `json:"deptId" dc:"部门id"` |
|||
} |
|||
|
|||
type GetShopInfoByDeptIdRes struct { |
|||
ShopId string `json:"shopId" orm:"db:cms;member_info;column:shopId" dc:"门店id"` |
|||
ShopName string `json:"shopName" orm:"db:cms;member_info;column:shopName" dc:"门店名"` |
|||
} |
|||
|
|||
type ExcelExportReq struct { |
|||
Jwcode int `json:"jwcode" dc:"精网号"` |
|||
Name string `json:"name" dc:"用户名字"` |
|||
DeptId string `json:"deptId" dc:"部门id"` |
|||
DeptName string `json:"deptName" dc:"部门名"` |
|||
ShopId string `json:"shopId" dc:"门店id"` |
|||
ShopName string `json:"shopName" dc:"门店名"` |
|||
Reply []Reply `json:"Reply" dc:"答案详情"` |
|||
} |
|||
|
|||
type Reply struct { |
|||
FormId int `json:"formId"` |
|||
Type int `json:"type"` |
|||
FormTitle string `json:"formTitle"` |
|||
ContentTitle string `json:"contentTitle"` |
|||
Content string `json:"content"` |
|||
SubmitTime gtime.Time `json:"submitTime"` |
|||
} |
@ -1,134 +1,92 @@ |
|||
github.com/BurntSushi/toml v1.2.0/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ= |
|||
github.com/360EntSecGroup-Skylar/excelize v1.4.1 h1:l55mJb6rkkaUzOpSsgEeKYtS6/0gHwBYyfo5Jcjv/Ks= |
|||
github.com/360EntSecGroup-Skylar/excelize v1.4.1/go.mod h1:vnax29X2usfl7HHkBrX5EvSCJcmH3dT9luvxzu8iGAE= |
|||
github.com/BurntSushi/toml v1.4.0 h1:kuoIxZQy2WRRk1pttg9asf+WVv6tWQuBNVmK8+nqPr0= |
|||
github.com/BurntSushi/toml v1.4.0/go.mod h1:ukJfTF/6rtPPRCnwkur4qwRxa8vTRFBF0uk2lLoLwho= |
|||
github.com/clbanning/mxj/v2 v2.7.0 h1:WA/La7UGCanFe5NpHF0Q3DNtnCsVoxbPKuyBNHWRyME= |
|||
github.com/clbanning/mxj/v2 v2.7.0/go.mod h1:hNiWqW14h+kc+MdF9C6/YoRfjEJoR3ou6tn/Qo+ve2s= |
|||
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= |
|||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= |
|||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= |
|||
github.com/emirpasic/gods v1.18.1 h1:FXtiHYKDGKCW2KzwZKx0iC0PQmdlorYgdFG9jPXJ1Bc= |
|||
github.com/emirpasic/gods v1.18.1/go.mod h1:8tpGGwCnJ5H4r6BWwaV6OrWmMoPhUl5jm/FMNAnJvWQ= |
|||
github.com/fatih/color v1.15.0/go.mod h1:0h5ZqXfHYED7Bhv2ZJamyIOUej9KtShiJESRwBDUSsw= |
|||
github.com/fatih/color v1.17.0 h1:GlRw1BRJxkpqUCBKzKOw098ed57fEsKeNjpTe3cSjK4= |
|||
github.com/fatih/color v1.17.0/go.mod h1:YZ7TlrGPkiz6ku9fK3TLD/pl3CpsiFyu8N92HLgmosI= |
|||
github.com/fsnotify/fsnotify v1.6.0/go.mod h1:sl3t1tCWJFWoRz9R8WJCbQihKKwmorjAbSClcnxKAGw= |
|||
github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA= |
|||
github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= |
|||
github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= |
|||
github.com/go-logr/logr v1.2.3/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= |
|||
github.com/go-logr/logr v1.2.4/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= |
|||
github.com/go-logr/logr v1.4.2 h1:6pFjapn8bFcIbiKo3XT4j/BhANplGihG6tvd+8rYgrY= |
|||
github.com/go-logr/logr v1.4.2/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= |
|||
github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag= |
|||
github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= |
|||
github.com/go-sql-driver/mysql v1.7.1 h1:lUIinVbN1DY0xBg0eMOzmmtGoHwWBbvnWubQUrtU8EI= |
|||
github.com/go-sql-driver/mysql v1.7.1/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI= |
|||
github.com/goflyfox/gtoken v1.5.10 h1:oj/v5r/1TjMMZvxpyEZYdsEvG2ZK/SGGnyjvsKi4uHk= |
|||
github.com/goflyfox/gtoken v1.5.10/go.mod h1:YpoSAn9tbfrSBoQnY7raQP0HaiRjQAE+4J179ecRH5I= |
|||
github.com/gogf/gf/contrib/drivers/mysql/v2 v2.8.1 h1:jbaPawkb8qmaYzrmBDbTa8Zkhzacq1RBOZw+qRJExI4= |
|||
github.com/gogf/gf/contrib/drivers/mysql/v2 v2.8.1/go.mod h1:s2aI1fV9AvKi4NtMpv3pV0EHtazkvfUNVQmzapr7UJQ= |
|||
github.com/gogf/gf/v2 v2.5.4/go.mod h1:7yf5qp0BznfsYx7Sw49m3mQvBsHpwAjJk3Q9ZnKoUEc= |
|||
github.com/gogf/gf/v2 v2.8.1 h1:1oVQg3G5OgCats4qWFTH3pHLe92nfUQeUDta05tUs1g= |
|||
github.com/gogf/gf/v2 v2.8.1/go.mod h1:6iYuZZ+A0ZcH8+4MDS/P0SvTPCvKzRvyAsY1kbkJYJc= |
|||
github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= |
|||
github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= |
|||
github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= |
|||
github.com/gorilla/websocket v1.5.0/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= |
|||
github.com/gorilla/websocket v1.5.3 h1:saDtZ6Pbx/0u+bgYQ3q96pZgCzfhKXGPqt7kZ72aNNg= |
|||
github.com/gorilla/websocket v1.5.3/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= |
|||
github.com/grokify/html-strip-tags-go v0.0.1/go.mod h1:2Su6romC5/1VXOQMaWL2yb618ARB8iVo6/DR99A6d78= |
|||
github.com/grokify/html-strip-tags-go v0.1.0 h1:03UrQLjAny8xci+R+qjCce/MYnpNXCtgzltlQbOBae4= |
|||
github.com/grokify/html-strip-tags-go v0.1.0/go.mod h1:ZdzgfHEzAfz9X6Xe5eBLVblWIxXfYSQ40S/VKrAOGpc= |
|||
github.com/magiconair/properties v1.8.6/go.mod h1:y3VJvCyxH9uVvJTWEGAELF3aiYNyPKd5NZ3oSwXrF60= |
|||
github.com/magiconair/properties v1.8.7 h1:IeQXZAiQcpL9mgcAe1Nu6cX9LLw6ExEHKjN0VQdvPDY= |
|||
github.com/magiconair/properties v1.8.7/go.mod h1:Dhd985XPs7jluiymwWYZ0G4Z61jb3vdS329zhj2hYo0= |
|||
github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= |
|||
github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= |
|||
github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= |
|||
github.com/mattn/go-isatty v0.0.17/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= |
|||
github.com/mattn/go-isatty v0.0.19/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= |
|||
github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= |
|||
github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= |
|||
github.com/mattn/go-runewidth v0.0.9/go.mod h1:H031xJmbD/WCDINGzjvQ9THkh0rPKHF+m2gUSrubnMI= |
|||
github.com/mattn/go-runewidth v0.0.15 h1:UNAjwbU9l54TA3KzvqLGxwWjHmMgBUVhBiTjelZgg3U= |
|||
github.com/mattn/go-runewidth v0.0.15/go.mod h1:Jdepj2loyihRzMpdS35Xk/zdY8IAYHsh153qUoGf23w= |
|||
github.com/mohae/deepcopy v0.0.0-20170929034955-c48cc78d4826 h1:RWengNIwukTxcDr9M+97sNutRR1RKhG96O6jWumTTnw= |
|||
github.com/mohae/deepcopy v0.0.0-20170929034955-c48cc78d4826/go.mod h1:TaXosZuwdSHYgviHp1DAtfrULt5eUgsSMsZf+YrPgl8= |
|||
github.com/olekukonko/tablewriter v0.0.5 h1:P2Ga83D34wi1o9J6Wh1mRuqd4mF/x/lgBS7N7AbDhec= |
|||
github.com/olekukonko/tablewriter v0.0.5/go.mod h1:hPp6KlRPjbx+hW8ykQs1w3UBbZlj6HuIJcUGPhkA7kY= |
|||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= |
|||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= |
|||
github.com/richardlehane/mscfb v1.0.4 h1:WULscsljNPConisD5hR0+OyZjwK46Pfyr6mPu5ZawpM= |
|||
github.com/richardlehane/mscfb v1.0.4/go.mod h1:YzVpcZg9czvAuhk9T+a3avCpcFPMUWm7gK3DypaEsUk= |
|||
github.com/richardlehane/msoleps v1.0.1/go.mod h1:BWev5JBpU9Ko2WAgmZEuiz4/u3ZYTKbjLycmwiWUfWg= |
|||
github.com/richardlehane/msoleps v1.0.4 h1:WuESlvhX3gH2IHcd8UqyCuFY5yiq/GR/yqaSM/9/g00= |
|||
github.com/richardlehane/msoleps v1.0.4/go.mod h1:BWev5JBpU9Ko2WAgmZEuiz4/u3ZYTKbjLycmwiWUfWg= |
|||
github.com/rivo/uniseg v0.2.0/go.mod h1:J6wj4VEh+S6ZtnVlnTBMWIodfgj8LQOQFoIToxlJtxc= |
|||
github.com/rivo/uniseg v0.4.4/go.mod h1:FN3SvrM+Zdj16jyLfmOkMNblXMcoc8DfTHruCPUcx88= |
|||
github.com/rivo/uniseg v0.4.7 h1:WUdvkW8uEhrYfLC4ZzdpI2ztxP1I582+49Oc5Mq64VQ= |
|||
github.com/rivo/uniseg v0.4.7/go.mod h1:FN3SvrM+Zdj16jyLfmOkMNblXMcoc8DfTHruCPUcx88= |
|||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= |
|||
github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= |
|||
github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= |
|||
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= |
|||
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= |
|||
github.com/stretchr/testify v1.8.2/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= |
|||
github.com/stretchr/testify v1.2.3-0.20181224173747-660f15d67dbb/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= |
|||
github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcUk= |
|||
github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= |
|||
github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY= |
|||
go.opentelemetry.io/otel v1.14.0/go.mod h1:o4buv+dJzx8rohcUeRmWUZhqupFvzWis188WlggnNeU= |
|||
github.com/xuri/efp v0.0.0-20240408161823-9ad904a10d6d h1:llb0neMWDQe87IzJLS4Ci7psK/lVsjIS2otl+1WyRyY= |
|||
github.com/xuri/efp v0.0.0-20240408161823-9ad904a10d6d/go.mod h1:ybY/Jr0T0GTCnYjKqmdwxyxn2BQf2RcQIIvex5QldPI= |
|||
github.com/xuri/excelize/v2 v2.9.0 h1:1tgOaEq92IOEumR1/JfYS/eR0KHOCsRv/rYXXh6YJQE= |
|||
github.com/xuri/excelize/v2 v2.9.0/go.mod h1:uqey4QBZ9gdMeWApPLdhm9x+9o2lq4iVmjiLfBS5hdE= |
|||
github.com/xuri/nfp v0.0.0-20240318013403-ab9948c2c4a7 h1:hPVCafDV85blFTabnqKgNhDCkJX25eik94Si9cTER4A= |
|||
github.com/xuri/nfp v0.0.0-20240318013403-ab9948c2c4a7/go.mod h1:WwHg+CVyzlv/TX9xqBFXEZAuxOPxn2k1GNHwG41IIUQ= |
|||
go.opentelemetry.io/otel v1.24.0 h1:0LAOdjNmQeSTzGBzduGe/rU4tZhMwL5rWgtp9Ku5Jfo= |
|||
go.opentelemetry.io/otel v1.24.0/go.mod h1:W7b9Ozg4nkF5tWI5zsXkaKKDjdVjpD4oAt9Qi/MArHo= |
|||
go.opentelemetry.io/otel/metric v1.24.0 h1:6EhoGWWK28x1fbpA4tYTOWBkPefTDQnb8WSGXlc88kI= |
|||
go.opentelemetry.io/otel/metric v1.24.0/go.mod h1:VYhLe1rFfxuTXLgj4CBiyz+9WYBA8pNGJgDcSFRKBco= |
|||
go.opentelemetry.io/otel/sdk v1.14.0/go.mod h1:bwIC5TjrNG6QDCHNWvW4HLHtUQ4I+VQDsnjhvyZCALM= |
|||
go.opentelemetry.io/otel/sdk v1.24.0 h1:YMPPDNymmQN3ZgczicBY3B6sf9n62Dlj9pWD3ucgoDw= |
|||
go.opentelemetry.io/otel/sdk v1.24.0/go.mod h1:KVrIYw6tEubO9E96HQpcmpTKDVn9gdv35HoYiQWGDFg= |
|||
go.opentelemetry.io/otel/trace v1.14.0/go.mod h1:8avnQLK+CG77yNLUae4ea2JDQ6iT+gozhnZjy/rw9G8= |
|||
go.opentelemetry.io/otel/trace v1.24.0 h1:CsKnnL4dUAr/0llH9FKuc698G04IrpWV0MQA/Y1YELI= |
|||
go.opentelemetry.io/otel/trace v1.24.0/go.mod h1:HPc3Xr/cOApsBI154IU0OI0HJexz+aw5uPdbs3UCjNU= |
|||
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= |
|||
golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= |
|||
golang.org/x/crypto v0.11.0/go.mod h1:xgJhtzW8F9jGdVFWZESrid1U1bjeNy4zgy5cRr/CIio= |
|||
golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= |
|||
golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= |
|||
golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= |
|||
golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= |
|||
golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= |
|||
golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= |
|||
golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= |
|||
golang.org/x/net v0.12.0/go.mod h1:zEVYFnQC7m/vmpQFELhcD1EWkZlX69l4oqgmer6hfKA= |
|||
golang.org/x/crypto v0.28.0 h1:GBDwsMXVQi34v5CCYUm2jkJvu4cbtru2U4TN2PSyQnw= |
|||
golang.org/x/crypto v0.28.0/go.mod h1:rmgy+3RHxRZMyY0jjAJShp2zgEdOqj2AO7U0pYmeQ7U= |
|||
golang.org/x/net v0.27.0 h1:5K3Njcw06/l2y9vpGCSdcxWOYHOUk3dVNGDXN+FvAys= |
|||
golang.org/x/net v0.27.0/go.mod h1:dDi0PyhWNoiUOrAS8uXv/vnScO4wnHQO4mj9fn/RytE= |
|||
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= |
|||
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= |
|||
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= |
|||
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= |
|||
golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= |
|||
golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
|||
golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
|||
golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
|||
golang.org/x/net v0.30.0 h1:AcW1SDZMkb8IpzCdQUaIq2sP4sZ4zw+55h6ynffypl4= |
|||
golang.org/x/net v0.30.0/go.mod h1:2wGyMJ5iFasEhkwi13ChkO/t1ECNC4X4eBKkVFyYFlU= |
|||
golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
|||
golang.org/x/sys v0.0.0-20220908164124-27713097b956/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
|||
golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
|||
golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
|||
golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
|||
golang.org/x/sys v0.10.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |
|||
golang.org/x/sys v0.22.0 h1:RI27ohtqKCnwULzJLqkv897zojh5/DwS/ENaMzUOaWI= |
|||
golang.org/x/sys v0.22.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= |
|||
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= |
|||
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= |
|||
golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= |
|||
golang.org/x/term v0.8.0/go.mod h1:xPskH00ivmX89bAKVGSKKtLOWNx2+17Eiy94tnKShWo= |
|||
golang.org/x/term v0.10.0/go.mod h1:lpqdcUyK/oCiQxvxVrppt5ggO2KCZ5QblwqPnfZ6d5o= |
|||
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= |
|||
golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= |
|||
golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= |
|||
golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= |
|||
golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8= |
|||
golang.org/x/text v0.11.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= |
|||
golang.org/x/sys v0.26.0 h1:KHjCJyddX0LoSTb3J+vWpupP9p0oznkqVk/IfjymZbo= |
|||
golang.org/x/sys v0.26.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= |
|||
golang.org/x/text v0.16.0 h1:a94ExnEXNtEwYLGJSIUxnWoxoRz/ZcCsV63ROupILh4= |
|||
golang.org/x/text v0.16.0/go.mod h1:GhwF1Be+LQoKShO3cGOHzqOgRrGaYc9AvblQOmPVHnI= |
|||
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= |
|||
golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= |
|||
golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= |
|||
golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU= |
|||
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= |
|||
golang.org/x/text v0.19.0 h1:kTxAhCbGbxhK0IwgSKiMO5awPoDQ0RpfiVYBfK860YM= |
|||
golang.org/x/text v0.19.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= |
|||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM= |
|||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= |
|||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= |
|||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= |
|||
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= |
@ -1 +0,0 @@ |
|||
package clientPage |
@ -0,0 +1,269 @@ |
|||
package record |
|||
|
|||
import ( |
|||
"github.com/360EntSecGroup-Skylar/excelize" |
|||
"github.com/gogf/gf/v2/net/ghttp" |
|||
"link_homework/api/v1/record" |
|||
"link_homework/internal/model/dto" |
|||
"link_homework/internal/service" |
|||
"log" |
|||
"net/http" |
|||
"strconv" |
|||
) |
|||
|
|||
type ManageRecord struct{} |
|||
|
|||
func NewManageRecord() *ManageRecord { |
|||
return &ManageRecord{} |
|||
} |
|||
|
|||
// 查询所有提交记录
|
|||
func (m *ManageRecord) GetRecordList(r *ghttp.Request) { |
|||
var req record.GetRecordListReq |
|||
if err := r.Parse(&req); err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
result, err := service.Record().GetRecordList(r.Context(), req.Id, req.PageNo, req.PageSize) |
|||
if err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 200, |
|||
Message: "success", |
|||
Data: result, |
|||
}) |
|||
} |
|||
|
|||
// 根据条件查询提交记录
|
|||
func (m *ManageRecord) GetRecordByCondition(r *ghttp.Request) { |
|||
var req record.GetRecordByConditionReq |
|||
if err := r.Parse(&req); err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
result, err := service.Record().GetRecordByCondition(r.Context(), req.Id, req.Jwcode, req.DeptId, req.ShopId, req.PageNo, req.PageSize) |
|||
if err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 200, |
|||
Message: "success", |
|||
Data: result, |
|||
}) |
|||
} |
|||
|
|||
// 查询用户部门信息
|
|||
func (m *ManageRecord) GetDeptInfo(r *ghttp.Request) { |
|||
result, err := service.Record().GetDeptInfo(r.Context()) |
|||
if err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 200, |
|||
Message: "success", |
|||
Data: result, |
|||
}) |
|||
} |
|||
|
|||
// 查询用户门店信息
|
|||
func (m *ManageRecord) GetShopInfo(r *ghttp.Request) { |
|||
var req record.GetShopInfoByDeptIdReq |
|||
if err := r.Parse(&req); err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
result, err := service.Record().GetShopInfoByDeptId(r.Context(), req.DeptId) |
|||
if err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 200, |
|||
Message: "success", |
|||
Data: result, |
|||
}) |
|||
} |
|||
|
|||
func (m *ManageRecord) ExeclExport(r *ghttp.Request) { |
|||
//获取前端传来的参数
|
|||
var req record.GetRecordByConditionReq |
|||
if err := r.Parse(&req); err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
//获取数据
|
|||
data, err := service.Record().GetRecordByCondition(r.Context(), req.Id, req.Jwcode, req.DeptId, req.ShopId, req.PageNo, req.PageSize) |
|||
if err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
|
|||
//创建文件
|
|||
f := excelize.NewFile() |
|||
sheet := "Sheet1" |
|||
f.NewSheet(sheet) |
|||
|
|||
////创建表头
|
|||
//var header []string
|
|||
////for _, field :=range reflect.Type(record.GetRecordListRes{}){
|
|||
//// header = append(header, field.Name)
|
|||
////}
|
|||
//for i := 0; i < reflect.TypeOf(record.GetRecordListRes{}).NumField(); i++ {
|
|||
// header = append(header, reflect.TypeOf(record.GetRecordListRes{}).Field(i).Name)
|
|||
//}
|
|||
|
|||
headers := []string{"精网号", "用户名字", "部门id", "部门名", "门店id", "门店名", "答案详情", "提交时间"} |
|||
headerStyle, err := f.NewStyle(`{"font":{"bold":true},"fill":{"type":"solid","color":"#4F81BD"}}`) |
|||
if err != nil { |
|||
r.Response.WriteJsonExit(dto.Result{ |
|||
Code: 400, |
|||
Message: err.Error(), |
|||
}) |
|||
} |
|||
for i, header := range headers { |
|||
cellName := getExcelColumnName(i) + "1" |
|||
f.SetCellValue(sheet, cellName, header) |
|||
f.SetCellStyle(sheet, cellName, cellName, headerStyle) |
|||
} |
|||
|
|||
//填充数据
|
|||
for rowIndex, row := range data { |
|||
// 假设 data 是一个 []GetRecordListRes 类型的切片
|
|||
rowData := row //.(record.GetRecordListRes) // 类型断言(这里需要确保 data 的类型是正确的)
|
|||
// 或者使用反射,但更推荐使用标签和直接映射
|
|||
f.SetCellValue(sheet, getExcelColumnName(0)+strconv.Itoa(rowIndex+2), rowData.Jwcode) |
|||
f.SetCellValue(sheet, getExcelColumnName(1)+strconv.Itoa(rowIndex+2), rowData.Name) |
|||
f.SetCellValue(sheet, getExcelColumnName(2)+strconv.Itoa(rowIndex+2), rowData.DeptName) |
|||
f.SetCellValue(sheet, getExcelColumnName(3)+strconv.Itoa(rowIndex+2), rowData.ShopName) |
|||
f.SetCellValue(sheet, getExcelColumnName(4)+strconv.Itoa(rowIndex+2), rowData.Reply) |
|||
f.SetCellValue(sheet, getExcelColumnName(5)+strconv.Itoa(rowIndex+2), rowData.Reply[0].UpdatedAt.Format("2006-01-02 15:04:05")) |
|||
} |
|||
|
|||
////定义表头样式,font:定义字体样式,如字体类型、字体大小、字体颜色等,Arial:字体家族为Arial.
|
|||
////fill:定义填充样式,如背景色
|
|||
//const (
|
|||
// headerStyleJSON = `{
|
|||
// "font": {
|
|||
// "bold": true,
|
|||
// "italic": false,
|
|||
// "family": "Arial",
|
|||
// "size": 14,
|
|||
// "color": "#FFFFFF" //更换成你想要的字体font
|
|||
// },
|
|||
// "fill": {
|
|||
// "type": "solid",
|
|||
// "color": "#4F81BD" // 更换为你想要的背景色
|
|||
// }
|
|||
// }`
|
|||
//)
|
|||
|
|||
////填充表头
|
|||
//headerStyle, err := f.NewStyle(headerStyleJSON)
|
|||
//if err != nil {
|
|||
// r.Response.WriteJsonExit(dto.Result{
|
|||
// Code: 400,
|
|||
// Message: err.Error(),
|
|||
// })
|
|||
//}
|
|||
//
|
|||
//for i, v := range header {
|
|||
// cell := fmt.Sprintf("%s%d", getExcelColumnName(i), 1)
|
|||
// f.SetCellValue(sheet, cell, v)
|
|||
// f.SetCellStyle(sheet, cell, cell, headerStyle)
|
|||
//}
|
|||
//
|
|||
////填充数据
|
|||
//for i, row := range data {
|
|||
// for j, col := range header {
|
|||
// cell := fmt.Sprintf("%s%d", getExcelColumnName(j), i+2)
|
|||
// //f.SetCellValue(sheet, cell, row[col])
|
|||
// f.SetCellValue(sheet, cell, row.FieldByName(col).Interface())
|
|||
// }
|
|||
//}
|
|||
|
|||
//设置默认打开的sheet
|
|||
f.SetActiveSheet(f.GetSheetIndex(sheet)) |
|||
|
|||
// 将 Excel 文件作为 HTTP 响应发送给客户端
|
|||
r.Response.Header().Set("Content-Type", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet") |
|||
r.Response.Header().Set("Content-Disposition", "attachment; filename=data.xlsx") |
|||
r.Response.WriteHeader(http.StatusOK) |
|||
if _, err := f.WriteTo(r.Response.Writer); err != nil { //这里有问题,说左右值数量不同,我加了个_
|
|||
// 处理错误(注意:这里可能无法再发送 JSON 响应,因为响应头已经发送)
|
|||
log.Printf("Error writing Excel file to response: %v", err) |
|||
} |
|||
|
|||
////保存文件
|
|||
//if err := f.SaveAs("data.xlsx"); err != nil {
|
|||
// r.Response.WriteJsonExit(dto.Result{
|
|||
// Code: 400,
|
|||
// Message: err.Error(),
|
|||
// })
|
|||
//}
|
|||
//
|
|||
//r.Response.WriteJsonExit(dto.Result{
|
|||
// Code: 200,
|
|||
// Message: "success",
|
|||
// Data: "data.xlsx",
|
|||
//})
|
|||
|
|||
} |
|||
|
|||
//func getExcelColumnName(index int) string {
|
|||
// var result string
|
|||
// for index > 0 {
|
|||
// index--
|
|||
// result = string('A'+index%26) + result
|
|||
// index /= 26
|
|||
// }
|
|||
// return result
|
|||
//}
|
|||
|
|||
// getExcelColumnName 将整数索引转换为 Excel 列名
|
|||
func getExcelColumnName(index int) string { |
|||
if index <= 0 { |
|||
return "" |
|||
} |
|||
|
|||
const letters = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" |
|||
var columnName string |
|||
|
|||
for index > 0 { |
|||
// 取余数得到当前位的字母
|
|||
remainder := index % 26 |
|||
// 将字母添加到结果字符串的前面
|
|||
columnName = string(letters[remainder-1]) + columnName |
|||
// 去掉已经处理过的最低位(因为 Excel 列名是从 1 开始计数的,所以这里要减 1)
|
|||
// 但由于我们是从后往前构建字符串,所以实际上是在下一次循环中处理 index/26 的结果
|
|||
index = (index - remainder) / 26 |
|||
// 由于上面的计算中 index-remainder 可能是 26 的倍数(当 remainder 为 0 时),这样会导致 index 多减 1,
|
|||
// 所以当 remainder 为 0 时,我们需要将 index 加回 1(或者等价地,不执行 index-- 操作)。
|
|||
// 但由于我们在循环中每次都会执行 index = (index - remainder) / 26,并且当 remainder 为 0 时,
|
|||
// (index - 0) / 26 实际上就是 index / 26,这是正确的。因此,我们不需要在这里对 remainder 为 0 的情况进行特殊处理。
|
|||
// 这里的注释主要是为了解释为什么上面的计算是正确的,以及为什么不需要对 remainder 为 0 的情况进行额外处理。
|
|||
} |
|||
|
|||
return columnName |
|||
} |
@ -1 +1,5 @@ |
|||
package logic |
|||
|
|||
import ( |
|||
_ "link_homework/internal/logic/record" |
|||
) |
@ -0,0 +1,148 @@ |
|||
package record |
|||
|
|||
import ( |
|||
"context" |
|||
"errors" |
|||
"fmt" |
|||
"github.com/gogf/gf/v2/frame/g" |
|||
pkgRecord "link_homework/api/v1/record" |
|||
"link_homework/internal/dao" |
|||
"link_homework/internal/model/dto" |
|||
"link_homework/internal/service" |
|||
) |
|||
|
|||
type sRecord struct{} |
|||
|
|||
func init() { |
|||
service.RegisterRecord(&sRecord{}) |
|||
} |
|||
|
|||
func NewRecord() *sRecord { |
|||
return &sRecord{} |
|||
} |
|||
|
|||
// 无条件全查
|
|||
func (s *sRecord) GetRecordList(ctx context.Context, groupId, pageNo, pageSize int) (record []pkgRecord.GetRecordListRes, err error) { |
|||
//从record表中查询出jwcode,根据group_id
|
|||
if pageNo == 0 && pageSize == 0 { |
|||
err = dao.ActivityInteractiveRecord.Ctx(ctx).Fields("jwcode").Where("group_id", groupId).Group("jwcode").Scan(&record) |
|||
} else { |
|||
err = dao.ActivityInteractiveRecord.Ctx(ctx).Fields("jwcode").Where("group_id", groupId).Group("jwcode"). |
|||
Page(pageNo, pageSize).Scan(&record) |
|||
} |
|||
if err != nil { |
|||
return nil, errors.New("无条件查jwcode失败") |
|||
} |
|||
|
|||
fmt.Println(record) |
|||
//根据jwcode在member_info表中查询姓名(name), 部门id(deptId), 部门名(deptName), 门店id(shopId), 门店名(shopName)
|
|||
for i, info := range record { |
|||
err = g.DB("cms").Model("member_info").Fields("jwcode", "name", "deptId", "deptName", "shopId", "shopName"). |
|||
Where("jwcode", info.Jwcode).Scan(&record[i]) |
|||
if err != nil { |
|||
return nil, errors.New("无条件根据jwcode查member_info表失败") |
|||
} |
|||
total, err1 := dao.ActivityInteractiveRecord.Ctx(ctx).Fields("jwcode").Where("group_id", groupId).Group("jwcode").Count() |
|||
if err1 != nil { |
|||
return |
|||
} |
|||
record[i].Total = total |
|||
//根据jwcode,groupId在record表中查询最新的提交记录进行存放
|
|||
var recordInfo []dto.RecordInfo |
|||
err = dao.ActivityInteractiveRecord.Ctx(ctx).Fields("content", "content_title", "updated_at", "form_id"). |
|||
Where("jwcode", info.Jwcode).Where("group_id", groupId).Group("form_id").Order("updated_at desc").Scan(&recordInfo) |
|||
if err != nil { |
|||
return nil, err |
|||
} |
|||
for i, title := range recordInfo { |
|||
err = dao.ActivityInteractiveForm.Ctx(ctx).Fields("description", "type").Where("id", title.FormId).Scan(&recordInfo[i]) |
|||
if err != nil { |
|||
return nil, err |
|||
} |
|||
} |
|||
record[i].Reply = recordInfo |
|||
fmt.Println(record) |
|||
} |
|||
return |
|||
} |
|||
|
|||
// 根据条件查询 对所有结果进行筛选
|
|||
func (s *sRecord) GetRecordByCondition(ctx context.Context, groupId, jwcode int, deptId, shopId string, pageNo, pageSize int) (record []pkgRecord.GetRecordListRes, err error) { |
|||
//全查
|
|||
recordList, err := s.GetRecordList(ctx, groupId, pageNo, pageSize) |
|||
if err != nil { |
|||
return recordList, err |
|||
} |
|||
//判断传来的jwcode, deptId, shopId是否为空,根据情况进行不同的筛选
|
|||
if jwcode == 0 { //没有传jwcode
|
|||
if deptId == "" && shopId == "" { //000
|
|||
return recordList, err |
|||
} else if deptId != "" && shopId == "" { //010
|
|||
for _, info := range recordList { |
|||
if info.DeptId == deptId { |
|||
record = append(record, info) |
|||
} |
|||
} |
|||
if record == nil { |
|||
return nil, errors.New("只部门没有查询到相关记录") |
|||
} |
|||
return record, err |
|||
} else if deptId != "" && shopId != "" { //011
|
|||
for _, info := range recordList { |
|||
if info.DeptId == deptId && info.ShopId == shopId { |
|||
record = append(record, info) |
|||
} |
|||
} |
|||
if record == nil { |
|||
return nil, errors.New("部门,门店 没有查询到相关记录") |
|||
} |
|||
return record, err |
|||
} |
|||
} else { //传了jwcode
|
|||
if deptId == "" && shopId == "" { //100
|
|||
for _, info := range recordList { |
|||
if info.Jwcode == jwcode { |
|||
record = append(record, info) |
|||
} |
|||
} |
|||
if record == nil { |
|||
return nil, errors.New("只精网号没有查询到相关记录") |
|||
} |
|||
return record, err |
|||
} else if deptId != "" && shopId == "" { //110
|
|||
for _, info := range recordList { |
|||
if info.Jwcode == jwcode && info.DeptId == deptId { |
|||
record = append(record, info) |
|||
} |
|||
} |
|||
if record == nil { |
|||
return nil, errors.New("精网号,部门 没有查询到相关记录") |
|||
} |
|||
return record, err |
|||
} else if deptId != "" && shopId != "" { //111
|
|||
for _, info := range recordList { |
|||
if info.Jwcode == jwcode && info.DeptId == deptId && info.ShopId == shopId { |
|||
record = append(record, info) |
|||
} |
|||
} |
|||
if record == nil { |
|||
return nil, errors.New("精网号,部门,门店 没有查询到相关记录") |
|||
} |
|||
return record, err |
|||
} |
|||
} |
|||
return nil, errors.New("检查一下穿的参数是否正常") |
|||
} |
|||
|
|||
// 查询部门信息
|
|||
func (s *sRecord) GetDeptInfo(ctx context.Context) (depts []pkgRecord.GetDeptInfoRes, err error) { |
|||
err = g.DB("cms").Model("member_info").Fields("deptId", "deptName").Group("deptId").Scan(&depts) |
|||
return |
|||
} |
|||
|
|||
// 根据部门信息查询门店信息
|
|||
func (s *sRecord) GetShopInfoByDeptId(ctx context.Context, deptId string) (shops []pkgRecord.GetShopInfoByDeptIdRes, err error) { |
|||
err = g.DB("cms").Model("member_info").Fields("shopId", "shopName"). |
|||
Where("deptId", deptId).Group("shopId").Scan(&shops) |
|||
return |
|||
} |
@ -0,0 +1,24 @@ |
|||
package dto |
|||
|
|||
import "github.com/gogf/gf/v2/os/gtime" |
|||
|
|||
// 从cms库中查询用户信息
|
|||
type MemberInfo struct { |
|||
Jwcode int `json:"jwcode" orm:"db:cms;table:member_info;column:jwcode" dc:"精网号"` |
|||
Name string `json:"name" orm:"db:cms;table:member_info;column:name" dc:"用户名字"` |
|||
DeptId string `json:"deptId" orm:"db:cms;table:member_info;column:deptId" dc:"部门id"` |
|||
DeptName string `json:"deptName" orm:"db:cms;member_info;column:deptName" dc:"部门名"` |
|||
ShopId string `json:"shopId" orm:"db:cms;member_info;column:shopId" dc:"门店id"` |
|||
ShopName string `json:"shopName" orm:"db:cms;member_info;column:shopName" dc:"门店名"` |
|||
} |
|||
|
|||
// 从live库里查询作业信息
|
|||
type RecordInfo struct { |
|||
//Jwcode int `json:"jwcode" orm:"db:default;table:activity_interactive_record;column:jwcode" dc:"精网号"`
|
|||
FormId int `json:"formId" orm:"db:default;table:activity_interactive_record;column:form_id" dc:"题目id"` |
|||
Type int `json:"type" orm:"db:default;table:activity_interactive_form;column:type" dc:"题目类型"` |
|||
Description string `json:"formTitle" orm:"db:default;table:activity_interactive_form;column:description" dc:"题目"` |
|||
ContentTitle string `json:"contentTitle" orm:"db:default;table:activity_interactive_record;column:content_title" dc:"作答标题"` |
|||
Content string `json:"content" orm:"db:default;table:activity_interactive_record;column:content" dc:"作答内容"` |
|||
UpdatedAt gtime.Time `json:"submitTime" orm:"db:default;table:activity_interactive_record;column:updated_at" dc:"提交时间/更新时间"` |
|||
} |
@ -0,0 +1,8 @@ |
|||
// ================================================================================
|
|||
// Code generated and maintained by GoFrame CLI tool. DO NOT EDIT.
|
|||
// You can delete these comments if you wish manually maintain this interface file.
|
|||
// ================================================================================
|
|||
|
|||
package service |
|||
|
|||
type () |
@ -0,0 +1,39 @@ |
|||
// ================================================================================
|
|||
// Code generated and maintained by GoFrame CLI tool. DO NOT EDIT.
|
|||
// You can delete these comments if you wish manually maintain this interface file.
|
|||
// ================================================================================
|
|||
|
|||
package service |
|||
|
|||
import ( |
|||
"context" |
|||
pkgRecord "link_homework/api/v1/record" |
|||
) |
|||
|
|||
type ( |
|||
IRecord interface { |
|||
// 无条件全查
|
|||
GetRecordList(ctx context.Context, groupId int, pageNo int, pageSize int) (record []pkgRecord.GetRecordListRes, err error) |
|||
// 根据条件查询 对所有结果进行筛选
|
|||
GetRecordByCondition(ctx context.Context, groupId int, jwcode int, deptId string, shopId string, pageNo int, pageSize int) (record []pkgRecord.GetRecordListRes, err error) |
|||
// 查询部门信息
|
|||
GetDeptInfo(ctx context.Context) (depts []pkgRecord.GetDeptInfoRes, err error) |
|||
// 根据部门信息查询门店信息
|
|||
GetShopInfoByDeptId(ctx context.Context, deptId string) (shops []pkgRecord.GetShopInfoByDeptIdRes, err error) |
|||
} |
|||
) |
|||
|
|||
var ( |
|||
localRecord IRecord |
|||
) |
|||
|
|||
func Record() IRecord { |
|||
if localRecord == nil { |
|||
panic("implement not found for interface IRecord, forgot register?") |
|||
} |
|||
return localRecord |
|||
} |
|||
|
|||
func RegisterRecord(i IRecord) { |
|||
localRecord = i |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue