智慧食堂
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

hdl_enterprise.go 22 KiB

1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
4ヶ月前
1年前
4ヶ月前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824
  1. package hdl
  2. import (
  3. enum2 "applet/app/admin/enum"
  4. "applet/app/admin/lib/validate"
  5. "applet/app/admin/md"
  6. "applet/app/admin/svc"
  7. "applet/app/db"
  8. "applet/app/db/model"
  9. "applet/app/e"
  10. "applet/app/enum"
  11. "applet/app/utils"
  12. "github.com/gin-gonic/gin"
  13. "time"
  14. )
  15. func EnterpriseList(c *gin.Context) {
  16. var req md.EnterpriseListReq
  17. err := c.ShouldBindJSON(&req)
  18. if err != nil {
  19. err = validate.HandleValidateErr(err)
  20. err1 := err.(e.E)
  21. e.OutErr(c, err1.Code, err1.Error())
  22. return
  23. }
  24. if req.Limit == 0 {
  25. req.Limit = 10
  26. }
  27. if req.Page == 0 {
  28. req.Page = 10
  29. }
  30. admin := svc.GetUser(c)
  31. enterprises, total, err := svc.EnterpriseList(*admin, req)
  32. if err != nil {
  33. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  34. return
  35. }
  36. e.OutSuc(c, map[string]interface{}{
  37. "list": enterprises,
  38. "total": total,
  39. "state": []map[string]interface{}{
  40. {
  41. "name": enum.EnterpriseState(enum.EnterpriseStateForNormal).String(),
  42. "value": enum.EnterpriseStateForNormal,
  43. },
  44. {
  45. "name": enum.EnterpriseState(enum.EnterpriseStateForFreeze).String(),
  46. "value": enum.EnterpriseStateForFreeze,
  47. },
  48. },
  49. "kind_by_mode": md.EnterpriseKindByMode,
  50. "pvd": []map[string]interface{}{
  51. {
  52. "name": enum.EnterprisePvd(enum.EnterprisePvdForOnlinePayment).String(),
  53. "value": enum.EnterprisePvdForOnlinePayment,
  54. },
  55. {
  56. "name": enum.EnterprisePvd(enum.EnterprisePvdForFaceScanPayment).String(),
  57. "value": enum.EnterprisePvdForFaceScanPayment,
  58. },
  59. },
  60. }, nil)
  61. return
  62. }
  63. func Detail(c *gin.Context) {
  64. enterpriseId := c.DefaultQuery("id", "")
  65. enterpriseDb := db.EnterpriseDb{}
  66. enterpriseDb.Set()
  67. enterprise, err := enterpriseDb.GetEnterprise(utils.StrToInt(enterpriseId))
  68. if err != nil {
  69. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  70. return
  71. }
  72. if enterprise.Pvd == enum.EnterprisePvdForFaceScanPayment && enterprise.Mode == enum.EnterpriseModeForSchool {
  73. detail, err := svc.EnterpriseDetailV2(utils.StrToInt(enterpriseId))
  74. if err != nil {
  75. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  76. return
  77. }
  78. e.OutSuc(c, detail, nil)
  79. return
  80. }
  81. detail, err := svc.EnterpriseDetail(utils.StrToInt(enterpriseId))
  82. if err != nil {
  83. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  84. return
  85. }
  86. e.OutSuc(c, detail, nil)
  87. return
  88. }
  89. func SchoolBelowGrade(c *gin.Context) {
  90. enterpriseId := c.DefaultQuery("enterprise_id", "")
  91. gradeDb := db.GradeDb{}
  92. gradeDb.Set(utils.StrToInt(enterpriseId))
  93. gradeList, err := gradeDb.FindGrade()
  94. if err != nil {
  95. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  96. return
  97. }
  98. e.OutSuc(c, map[string]interface{}{
  99. "list": gradeList,
  100. }, nil)
  101. return
  102. }
  103. func PeriodBelowGrade(c *gin.Context) {
  104. periodId := c.DefaultQuery("period_id", "")
  105. periodDb := db.PeriodDb{}
  106. periodDb.Set(0)
  107. period, err1 := periodDb.GetPeriod(utils.StrToInt(periodId))
  108. if err1 != nil {
  109. e.OutErr(c, e.ERR_DB_ORM, err1.Error())
  110. return
  111. }
  112. if period == nil {
  113. e.OutErr(c, e.ERR_NO_DATA, "未查询到相关学段信息")
  114. return
  115. }
  116. gradeDb := db.GradeDb{}
  117. gradeDb.Set(period.EnterpriseId)
  118. gradeList, err := gradeDb.FindGradeByPeriodId(period.Id)
  119. if err != nil {
  120. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  121. return
  122. }
  123. e.OutSuc(c, map[string]interface{}{
  124. "list": gradeList,
  125. }, nil)
  126. return
  127. }
  128. func SchoolBelowPeriod(c *gin.Context) {
  129. enterpriseId := c.DefaultQuery("enterprise_id", "")
  130. periodDb := db.PeriodDb{}
  131. periodDb.Set(utils.StrToInt(enterpriseId))
  132. periodList, err := periodDb.FindPeriod()
  133. if err != nil {
  134. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  135. return
  136. }
  137. e.OutSuc(c, map[string]interface{}{
  138. "list": periodList,
  139. }, nil)
  140. return
  141. }
  142. func SchoolGradeBelowClass(c *gin.Context) {
  143. gradeId := c.DefaultQuery("grade_id", "")
  144. enterpriseId := c.DefaultQuery("enterprise_id", "")
  145. classDb := db.ClassDb{}
  146. if gradeId != "" {
  147. classDb.Set(utils.StrToInt(gradeId))
  148. classList, err := classDb.FindClass()
  149. if err != nil {
  150. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  151. return
  152. }
  153. e.OutSuc(c, map[string]interface{}{
  154. "list": classList,
  155. }, nil)
  156. } else {
  157. classDb.Set(0)
  158. classList, err := classDb.FindClassByEnterprise(enterpriseId)
  159. if err != nil {
  160. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  161. return
  162. }
  163. e.OutSuc(c, map[string]interface{}{
  164. "list": classList,
  165. }, nil)
  166. }
  167. return
  168. }
  169. func EnterpriseAdd(c *gin.Context) {
  170. var req md.EnterpriseAddReq
  171. err := c.ShouldBindJSON(&req)
  172. if err != nil {
  173. err = validate.HandleValidateErr(err)
  174. err1 := err.(e.E)
  175. e.OutErr(c, err1.Code, err1.Error())
  176. return
  177. }
  178. enterpriseDb := db.EnterpriseDb{}
  179. enterpriseDb.Set()
  180. now := time.Now()
  181. //var pvd = 2
  182. //if req.Kind == enum.EnterpriseKindByCentralKitchenForSchool || req.Kind == enum.EnterpriseKindByCentralKitchenForFactory {
  183. // pvd = 1
  184. //}
  185. enterprise := model.Enterprise{
  186. Name: req.Name,
  187. Pvd: req.Pvd,
  188. Mode: req.Mode,
  189. Kind: req.Kind,
  190. CompanyId: req.CompanyId,
  191. State: enum2.CompanyStateForNormal,
  192. Memo: req.Memo,
  193. CreateAt: now.Format("2006-01-02 15:04:05"),
  194. UpdateAt: now.Format("2006-01-02 15:04:05"),
  195. }
  196. enterpriseId, err := enterpriseDb.EnterpriseInsert(&enterprise)
  197. if err != nil {
  198. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  199. return
  200. }
  201. if req.Pvd == enum.EnterprisePvdForOnlinePayment && req.Mode == enum.EnterpriseModeForSchool {
  202. //新增 `central_kitchen_for_school_set` && `central_kitchen_for_school_with_spec`
  203. centralKitchenForSchoolSetDb := db.CentralKitchenForSchoolSetDb{}
  204. centralKitchenForSchoolSetDb.Set(enterpriseId)
  205. centralKitchenForSchoolSetDb.CentralKitchenForSchoolSetInsert(&model.CentralKitchenForSchoolSet{
  206. EnterpriseId: enterpriseId,
  207. IsOpenTeacherReportMeal: 1,
  208. IsOpenReportMealForDay: 1,
  209. IsOpenReportMealForMonth: 1,
  210. IsOpenReportMealForSemester: 1,
  211. IsOpenTeacherReportMealForDay: 1,
  212. IsOpenTeacherReportMealForMonth: 1,
  213. IsOpenTeacherReportMealForSemester: 1,
  214. CreateAt: now.Format("2006-01-02 15:04:05"),
  215. UpdateAt: now.Format("2006-01-02 15:04:05"),
  216. })
  217. centralKitchenForSchoolWithSpec := db.CentralKitchenForSchoolWithSpec{}
  218. centralKitchenForSchoolWithSpec.Set(enterpriseId)
  219. centralKitchenForSchoolWithSpec.CentralKitchenForSchoolWithSpecInsert(&model.CentralKitchenForSchoolWithSpec{
  220. EnterpriseId: enterpriseId,
  221. IsOpenBreakfast: 1,
  222. IsOpenLunch: 1,
  223. IsOpenDinner: 1,
  224. IsOpenBreakfastForTeacher: 1,
  225. IsOpenLunchForTeacher: 1,
  226. IsOpenDinnerForTeacher: 1,
  227. BreakfastUnitPrice: "0.00",
  228. LunchUnitPrice: "0.00",
  229. DinnerUnitPrice: "0.00",
  230. BreakfastUnitPriceForTeacher: "0.00",
  231. LunchUnitPriceForTeacher: "0.00",
  232. DinnerUnitPriceForTeacher: "0.00",
  233. BreakfastTeacherNotice: "",
  234. LunchTeacherNotice: "",
  235. DinnerTeacherNotice: "",
  236. CreateAt: now.Format("2006-01-02 15:04:05"),
  237. UpdateAt: now.Format("2006-01-02 15:04:05"),
  238. })
  239. }
  240. if req.Kind == enum.EnterpriseKindByNursingHome {
  241. //新增 `nursing_home_set` && `nursing_home_with_spec`
  242. nursingHomeSetDb := db.NursingHomeSetDb{}
  243. nursingHomeSetDb.Set(enterpriseId)
  244. nursingHomeSetDb.NursingHomeSetInsert(&model.NursingHomeSet{
  245. EnterpriseId: enterpriseId,
  246. IsOpenReportMealForDay: 1,
  247. IsOpenReportMealForMonth: 1,
  248. IsOpenReportMealForYear: 1,
  249. CreateAt: now.Format("2006-01-02 15:04:05"),
  250. UpdateAt: now.Format("2006-01-02 15:04:05"),
  251. })
  252. nursingHomeWithSpec := db.NursingHomeWithSpec{}
  253. nursingHomeWithSpec.Set(enterpriseId)
  254. nursingHomeWithSpec.NursingHomeWithSpecInsert(&model.NursingHomeWithSpec{
  255. EnterpriseId: enterpriseId,
  256. IsOpenBreakfast: 1,
  257. IsOpenLunch: 1,
  258. IsOpenDinner: 1,
  259. BreakfastUnitPrice: "0.00",
  260. LunchUnitPrice: "0.00",
  261. DinnerUnitPrice: "0.00",
  262. CreateAt: now.Format("2006-01-02 15:04:05"),
  263. UpdateAt: now.Format("2006-01-02 15:04:05"),
  264. })
  265. }
  266. e.OutSuc(c, "success", nil)
  267. return
  268. }
  269. func EnterpriseDelete(c *gin.Context) {
  270. var req md.EnterpriseDeleteReq
  271. err := c.ShouldBindJSON(&req)
  272. if err != nil {
  273. err = validate.HandleValidateErr(err)
  274. err1 := err.(e.E)
  275. e.OutErr(c, err1.Code, err1.Error())
  276. return
  277. }
  278. err = svc.EnterpriseDelete(req.EnterpriseIds)
  279. if err != nil {
  280. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  281. return
  282. }
  283. e.OutSuc(c, "success", nil)
  284. return
  285. }
  286. func CentralKitchenForSchoolUpdate(c *gin.Context) {
  287. var req md.CentralKitchenForSchoolUpdateReq
  288. err := c.ShouldBindJSON(&req)
  289. if err != nil {
  290. err = validate.HandleValidateErr(err)
  291. err1 := err.(e.E)
  292. e.OutErr(c, err1.Code, err1.Error())
  293. return
  294. }
  295. //1、更新 enterprise
  296. enterpriseDb := db.EnterpriseDb{}
  297. enterpriseDb.Set()
  298. enterprise, err := enterpriseDb.GetEnterprise(req.Id)
  299. if err != nil {
  300. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  301. return
  302. }
  303. if enterprise == nil {
  304. e.OutErr(c, e.ERR_NO_DATA, "未查询到对应记录")
  305. return
  306. }
  307. now := time.Now()
  308. enterprise.Name = req.Name
  309. enterprise.Memo = req.Memo
  310. enterprise.CompanyId = req.CompanyId
  311. enterprise.UpdateAt = now.Format("2006-01-02 15:04:05")
  312. _, err = enterpriseDb.EnterpriseUpdate(enterprise, "name", "memo", "company_id", "update_at")
  313. if err != nil {
  314. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  315. return
  316. }
  317. //2、更新 period && grade && class 数据
  318. periodDb := db.PeriodDb{}
  319. periodDb.Set(req.Id)
  320. gradeDb := db.GradeDb{}
  321. gradeDb.Set(req.Id)
  322. classDb := db.ClassDb{}
  323. classDb.Set(0)
  324. //新增 grade 数据 && class 数据
  325. var classes []*model.Class
  326. for _, v := range req.PeriodList {
  327. if v.Id == 0 {
  328. //TODO::新增
  329. insertId, err1 := periodDb.PeriodInsert(&model.Period{
  330. EnterpriseId: req.Id,
  331. Name: v.Name,
  332. BreakfastUnitPrice: "0.00",
  333. LunchUnitPrice: "0.00",
  334. DinnerUnitPrice: "0.00",
  335. CreateAt: now.Format("2006-01-02 15:04:05"),
  336. UpdateAt: now.Format("2006-01-02 15:04:05"),
  337. })
  338. if err1 != nil {
  339. e.OutErr(c, e.ERR_DB_ORM, err1.Error())
  340. return
  341. }
  342. for _, v1 := range v.GradeList {
  343. insertId1, err2 := gradeDb.GradeInsert(&model.Grade{
  344. Name: v1.Name,
  345. Memo: "",
  346. PeriodId: insertId,
  347. EnterpriseId: req.Id,
  348. CreateAt: now.Format("2006-01-02 15:04:05"),
  349. UpdateAt: now.Format("2006-01-02 15:04:05"),
  350. })
  351. if err2 != nil {
  352. e.OutErr(c, e.ERR_DB_ORM, err2.Error())
  353. return
  354. }
  355. for _, v2 := range v1.ClassList {
  356. classes = append(classes, &model.Class{
  357. Name: v2.Name,
  358. Memo: "",
  359. GradeId: insertId1,
  360. EnterpriseId: req.Id,
  361. CreateAt: now.Format("2006-01-02 15:04:05"),
  362. UpdateAt: now.Format("2006-01-02 15:04:05"),
  363. })
  364. }
  365. }
  366. } else {
  367. //TODO::编辑
  368. period, err1 := periodDb.GetPeriod(v.Id)
  369. if err1 != nil {
  370. e.OutErr(c, e.ERR_DB_ORM, err1.Error())
  371. return
  372. }
  373. if period == nil {
  374. e.OutErr(c, e.ERR_NO_DATA, "未查询到相关学段信息")
  375. return
  376. }
  377. period.Name = v.Name
  378. _, err2 := periodDb.PeriodUpdate(period, "name")
  379. if err2 != nil {
  380. e.OutErr(c, e.ERR_DB_ORM, err2.Error())
  381. return
  382. }
  383. for _, v1 := range v.GradeList {
  384. var gradeId int
  385. if v1.Id == 0 {
  386. gradeId, err2 = gradeDb.GradeInsert(&model.Grade{
  387. Name: v1.Name,
  388. Memo: "",
  389. PeriodId: period.Id,
  390. EnterpriseId: req.Id,
  391. CreateAt: now.Format("2006-01-02 15:04:05"),
  392. UpdateAt: now.Format("2006-01-02 15:04:05"),
  393. })
  394. if err2 != nil {
  395. e.OutErr(c, e.ERR_DB_ORM, err2.Error())
  396. return
  397. }
  398. } else {
  399. grade, err3 := gradeDb.GetGrade(v1.Id)
  400. if err3 != nil {
  401. e.OutErr(c, e.ERR_DB_ORM, err3.Error())
  402. return
  403. }
  404. if grade == nil {
  405. e.OutErr(c, e.ERR_NO_DATA, "未查询到相关年级信息")
  406. return
  407. }
  408. grade.Name = v1.Name
  409. _, err4 := gradeDb.GradeUpdate(grade, "name")
  410. if err4 != nil {
  411. e.OutErr(c, e.ERR_DB_ORM, err4.Error())
  412. return
  413. }
  414. gradeId = grade.Id
  415. }
  416. for _, v2 := range v1.ClassList {
  417. if v2.Id == 0 {
  418. //新增
  419. classes = append(classes, &model.Class{
  420. Name: v2.Name,
  421. Memo: "",
  422. GradeId: gradeId,
  423. EnterpriseId: req.Id,
  424. CreateAt: now.Format("2006-01-02 15:04:05"),
  425. UpdateAt: now.Format("2006-01-02 15:04:05"),
  426. })
  427. } else {
  428. //编辑
  429. class, err4 := classDb.GetClass(v2.Id)
  430. if err4 != nil {
  431. e.OutErr(c, e.ERR_DB_ORM, err4.Error())
  432. return
  433. }
  434. if class == nil {
  435. e.OutErr(c, e.ERR_NO_DATA, "未查询到相关班级信息")
  436. return
  437. }
  438. class.Name = v2.Name
  439. _, err6 := classDb.ClassUpdate(class, "name")
  440. if err6 != nil {
  441. e.OutErr(c, e.ERR_DB_ORM, err6.Error())
  442. return
  443. }
  444. }
  445. }
  446. }
  447. }
  448. }
  449. if len(classes) > 0 {
  450. _, err2 := classDb.BatchAddClass(classes)
  451. if err2 != nil {
  452. e.OutErr(c, e.ERR_DB_ORM, err2.Error())
  453. return
  454. }
  455. }
  456. e.OutSuc(c, "success", nil)
  457. return
  458. }
  459. func SelfSupportForSchoolUpdate(c *gin.Context) {
  460. var req md.SelfSupportForSchoolUpdateReq
  461. err := c.ShouldBindJSON(&req)
  462. if err != nil {
  463. err = validate.HandleValidateErr(err)
  464. err1 := err.(e.E)
  465. e.OutErr(c, err1.Code, err1.Error())
  466. return
  467. }
  468. //1、更新 enterprise
  469. enterpriseDb := db.EnterpriseDb{}
  470. enterpriseDb.Set()
  471. enterprise, err := enterpriseDb.GetEnterprise(req.Id)
  472. if err != nil {
  473. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  474. return
  475. }
  476. if enterprise == nil {
  477. e.OutErr(c, e.ERR_NO_DATA, "未查询到对应记录")
  478. return
  479. }
  480. now := time.Now()
  481. enterprise.Name = req.Name
  482. enterprise.Memo = req.Memo
  483. enterprise.CompanyId = req.CompanyId
  484. enterprise.UpdateAt = now.Format("2006-01-02 15:04:05")
  485. _, err = enterpriseDb.EnterpriseUpdate(enterprise, "name", "memo", "company_id", "update_at")
  486. if err != nil {
  487. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  488. return
  489. }
  490. //2、更新 grade && class 数据
  491. //2、删除 grade && class 数据
  492. gradeDb := db.GradeDb{}
  493. gradeDb.Set(req.Id)
  494. //_, err = gradeDb.ClassDeleteBySessionForEnterprise(db.Db.NewSession(), req.Id)
  495. //if err != nil {
  496. // e.OutErr(c, e.ERR_DB_ORM, err.Error())
  497. // return
  498. //}
  499. classDb := db.ClassDb{}
  500. classDb.Set(0)
  501. //_, err = classDb.ClassDeleteBySessionForEnterprise(db.Db.NewSession(), req.Id)
  502. //if err != nil {
  503. // e.OutErr(c, e.ERR_DB_ORM, err.Error())
  504. // return
  505. //}
  506. //新增 grade 数据 && class 数据
  507. for _, v := range req.GradeList {
  508. var classes []*model.Class
  509. if v.Id == 0 {
  510. //TODO::新增
  511. insertId, err1 := gradeDb.GradeInsert(&model.Grade{
  512. EnterpriseId: req.Id,
  513. Name: v.Name,
  514. Memo: "",
  515. CreateAt: now.Format("2006-01-02 15:04:05"),
  516. UpdateAt: now.Format("2006-01-02 15:04:05"),
  517. })
  518. if err1 != nil {
  519. e.OutErr(c, e.ERR_DB_ORM, err1.Error())
  520. return
  521. }
  522. for _, v1 := range v.ClassList {
  523. classes = append(classes, &model.Class{
  524. Name: v1.Name,
  525. Memo: "",
  526. GradeId: insertId,
  527. EnterpriseId: req.Id,
  528. CreateAt: now.Format("2006-01-02 15:04:05"),
  529. UpdateAt: now.Format("2006-01-02 15:04:05"),
  530. })
  531. }
  532. } else {
  533. //TODO::编辑
  534. grade, err3 := gradeDb.GetGrade(v.Id)
  535. if err3 != nil {
  536. e.OutErr(c, e.ERR_DB_ORM, err3.Error())
  537. return
  538. }
  539. if grade == nil {
  540. e.OutErr(c, e.ERR_NO_DATA, "未查询到相关年级信息")
  541. return
  542. }
  543. grade.Name = v.Name
  544. _, err4 := gradeDb.GradeUpdate(grade, "name")
  545. if err4 != nil {
  546. e.OutErr(c, e.ERR_DB_ORM, err4.Error())
  547. return
  548. }
  549. for _, v1 := range v.ClassList {
  550. if v1.Id == 0 {
  551. //新增
  552. classes = append(classes, &model.Class{
  553. Name: v1.Name,
  554. Memo: "",
  555. GradeId: grade.Id,
  556. EnterpriseId: req.Id,
  557. CreateAt: now.Format("2006-01-02 15:04:05"),
  558. UpdateAt: now.Format("2006-01-02 15:04:05"),
  559. })
  560. } else {
  561. //编辑
  562. class, err5 := classDb.GetClass(v1.Id)
  563. if err5 != nil {
  564. e.OutErr(c, e.ERR_DB_ORM, err5.Error())
  565. return
  566. }
  567. if class == nil {
  568. e.OutErr(c, e.ERR_NO_DATA, "未查询到相关班级信息")
  569. return
  570. }
  571. class.Name = v1.Name
  572. _, err6 := classDb.ClassUpdate(class, "name")
  573. if err6 != nil {
  574. e.OutErr(c, e.ERR_DB_ORM, err6.Error())
  575. return
  576. }
  577. }
  578. }
  579. }
  580. if len(classes) > 0 {
  581. _, err2 := classDb.BatchAddClass(classes)
  582. if err2 != nil {
  583. e.OutErr(c, e.ERR_DB_ORM, err2.Error())
  584. return
  585. }
  586. }
  587. }
  588. e.OutSuc(c, "success", nil)
  589. return
  590. }
  591. func EnterpriseAddGrade(c *gin.Context) {
  592. var req md.EnterpriseUpdateStateReq
  593. err := c.ShouldBindJSON(&req)
  594. if err != nil {
  595. err = validate.HandleValidateErr(err)
  596. err1 := err.(e.E)
  597. e.OutErr(c, err1.Code, err1.Error())
  598. return
  599. }
  600. enterpriseDb := db.EnterpriseDb{}
  601. enterpriseDb.Set()
  602. enterprise, err := enterpriseDb.GetEnterprise(req.Id)
  603. if err != nil {
  604. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  605. return
  606. }
  607. if enterprise == nil {
  608. e.OutErr(c, e.ERR_NO_DATA, "未查询到对应记录")
  609. return
  610. }
  611. now := time.Now()
  612. enterprise.State = req.State
  613. enterprise.UpdateAt = now.Format("2006-01-02 15:04:05")
  614. _, err = enterpriseDb.EnterpriseUpdate(enterprise, "state", "update_at")
  615. if err != nil {
  616. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  617. return
  618. }
  619. e.OutSuc(c, "success", nil)
  620. return
  621. }
  622. func EnterpriseUpdateState(c *gin.Context) {
  623. var req md.EnterpriseUpdateStateReq
  624. err := c.ShouldBindJSON(&req)
  625. if err != nil {
  626. err = validate.HandleValidateErr(err)
  627. err1 := err.(e.E)
  628. e.OutErr(c, err1.Code, err1.Error())
  629. return
  630. }
  631. enterpriseDb := db.EnterpriseDb{}
  632. enterpriseDb.Set()
  633. enterprise, err := enterpriseDb.GetEnterprise(req.Id)
  634. if err != nil {
  635. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  636. return
  637. }
  638. if enterprise == nil {
  639. e.OutErr(c, e.ERR_NO_DATA, "未查询到对应记录")
  640. return
  641. }
  642. now := time.Now()
  643. enterprise.State = req.State
  644. enterprise.UpdateAt = now.Format("2006-01-02 15:04:05")
  645. _, err = enterpriseDb.EnterpriseUpdate(enterprise, "state", "update_at")
  646. if err != nil {
  647. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  648. return
  649. }
  650. e.OutSuc(c, "success", nil)
  651. return
  652. }
  653. func ListCentralKitchenForSchoolPackageForSystem(c *gin.Context) {
  654. var req md.ListCentralKitchenForSchoolPackageForSystemReq
  655. err := c.ShouldBindJSON(&req)
  656. if err != nil {
  657. err = validate.HandleValidateErr(err)
  658. err1 := err.(e.E)
  659. e.OutErr(c, err1.Code, err1.Error())
  660. return
  661. }
  662. centralKitchenForSchoolPackageForSystemDb := db.CentralKitchenForSchoolPackageForSystemDb{}
  663. centralKitchenForSchoolPackageForSystemDb.Set()
  664. list, total, err := centralKitchenForSchoolPackageForSystemDb.CentralKitchenForSchoolPackageForSystemList(req)
  665. if err != nil {
  666. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  667. return
  668. }
  669. e.OutSuc(c, map[string]interface{}{
  670. "list": list,
  671. "total": total,
  672. }, nil)
  673. return
  674. }
  675. func SetCentralKitchenForSchoolWithSpecForSystem(c *gin.Context) {
  676. var req md.SetCentralKitchenForSchoolWithSpecForSystemReq
  677. err := c.ShouldBindJSON(&req)
  678. if err != nil {
  679. err = validate.HandleValidateErr(err)
  680. err1 := err.(e.E)
  681. e.OutErr(c, err1.Code, err1.Error())
  682. return
  683. }
  684. centralKitchenForSchoolWithSpecForSystemDb := db.CentralKitchenForSchoolWithSpecForSystem{}
  685. centralKitchenForSchoolWithSpecForSystemDb.Set()
  686. system, err := centralKitchenForSchoolWithSpecForSystemDb.GetCentralKitchenForSchoolWithSpecForSystem()
  687. if err != nil {
  688. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  689. return
  690. }
  691. system.BreakfastUnitPrice = req.BreakfastUnitPrice
  692. system.LunchUnitPrice = req.LunchUnitPrice
  693. system.DinnerUnitPrice = req.DinnerUnitPrice
  694. system.BreakfastUnitPriceForTeacher = req.BreakfastUnitPriceForTeacher
  695. system.LunchUnitPriceForTeacher = req.LunchUnitPriceForTeacher
  696. system.DinnerUnitPriceForTeacher = req.DinnerUnitPriceForTeacher
  697. system.UpdateAt = time.Now().Format("2006-01-02 15:04:05")
  698. updateAffected, err := centralKitchenForSchoolWithSpecForSystemDb.CentralKitchenForSchoolWithSpecForSystemUpdate(system.Id, system)
  699. if err != nil {
  700. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  701. return
  702. }
  703. if updateAffected <= 0 {
  704. e.OutErr(c, e.ERR, "更新数据失败")
  705. return
  706. }
  707. e.OutSuc(c, "success", nil)
  708. return
  709. }
  710. func GetCentralKitchenForSchoolWithSpecForSystem(c *gin.Context) {
  711. centralKitchenForSchoolWithSpecForSystemDb := db.CentralKitchenForSchoolWithSpecForSystem{}
  712. centralKitchenForSchoolWithSpecForSystemDb.Set()
  713. system, err := centralKitchenForSchoolWithSpecForSystemDb.GetCentralKitchenForSchoolWithSpecForSystem()
  714. if err != nil {
  715. e.OutErr(c, e.ERR_DB_ORM, err.Error())
  716. return
  717. }
  718. e.OutSuc(c, map[string]interface{}{
  719. "data": system,
  720. }, nil)
  721. return
  722. }
  723. func SaveCentralKitchenForSchoolPackageForSystem(c *gin.Context) {
  724. var req md.SaveCentralKitchenForSchoolPackageForSystemReq
  725. err := c.ShouldBindJSON(&req)
  726. if err != nil {
  727. err = validate.HandleValidateErr(err)
  728. err1 := err.(e.E)
  729. e.OutErr(c, err1.Code, err1.Error())
  730. return
  731. }
  732. //判断是新增 / 编辑
  733. if req.Id > 0 {
  734. err = svc.UpdateCentralKitchenForSchoolPackageForSystem(req)
  735. if err != nil {
  736. e.OutErr(c, e.ERR, err.Error())
  737. return
  738. }
  739. } else {
  740. err = svc.AddCentralKitchenForSchoolPackageForSystem(req)
  741. if err != nil {
  742. e.OutErr(c, e.ERR, err.Error())
  743. return
  744. }
  745. }
  746. e.OutSuc(c, "success", nil)
  747. return
  748. }
  749. func SyncCentralKitchenForSchoolPackageForSystem(c *gin.Context) {
  750. var req md.SyncCentralKitchenForSchoolPackageForSystemReq
  751. err := c.ShouldBindJSON(&req)
  752. if err != nil {
  753. err = validate.HandleValidateErr(err)
  754. err1 := err.(e.E)
  755. e.OutErr(c, err1.Code, err1.Error())
  756. return
  757. }
  758. err = svc.SyncCentralKitchenForSchoolPackageForSystem(req)
  759. if err != nil {
  760. e.OutErr(c, e.ERR, err.Error())
  761. return
  762. }
  763. e.OutSuc(c, "success", nil)
  764. return
  765. }
  766. func DeleteCentralKitchenForSchoolPackageForSystem(c *gin.Context) {
  767. id := c.Param("id")
  768. err := svc.DeleteCentralKitchenForSchoolPackageForSystem(utils.StrToInt(id))
  769. if err != nil {
  770. e.OutErr(c, e.ERR, err.Error())
  771. return
  772. }
  773. e.OutSuc(c, "success", nil)
  774. return
  775. }