IntegralProjectApi.php 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <?php
  2. namespace app\common\api;
  3. use app\common\model\IntegralProject;
  4. class IntegralProjectApi {
  5. public static function getOne($id) {
  6. return IntegralProject::findOrEmpty($id);
  7. }
  8. public static function getList($params) {
  9. $order = $params["order"] ?: "desc";
  10. $offset = $params["offset"] ?: 0;
  11. $limit = $params["limit"] ?: 10;
  12. $where[] = ["delete", "=", 0];
  13. if ($params["type"]) {
  14. $where[] = ["type", "=", $params["type"]];
  15. }
  16. if ($params["name"]) {
  17. $where[] = ["name", "like", "%{$params["name"]}%"];
  18. }
  19. if ($params["projectType"]) {
  20. $where[] = ["projectType", "=", $params["projectType"]];
  21. }
  22. if ($params["active"]) {
  23. $where[] = ["active", "=", $params["active"]];
  24. }
  25. $count = IntegralProject::where($where)->count();
  26. $list = IntegralProject::where($where)->field("*,if(updateTime is null,createTime,updateTime) as orderTime")->limit($offset, $limit)->order("orderTime desc")->select()->toArray();
  27. return ["total" => $count, "rows" => $list];
  28. }
  29. public static function getAll($where = []) {
  30. $where[] = ["delete", "=", 0];
  31. $list = IntegralProject::where($where)->order("updateTime desc,createTime desc")->select()->toArray();
  32. return $list;
  33. }
  34. public static function edit($params) {
  35. $data["type"] = $params["type"];
  36. $data["name"] = $params["name"];
  37. $data["projectType"] = $params["projectType"];
  38. $data["active"] = $params["active"];
  39. $data["limit"] = $params["limit"];
  40. if ($data["limit"] == 1) {
  41. $data["yearly"] = $params["yearly"];
  42. $data["max"] = $params["max"];
  43. } else {
  44. $data["yearly"] = 0;
  45. $data["max"] = 0;
  46. }
  47. if ($params["id"]) {
  48. $data["id"] = $params["id"];
  49. $data["updateTime"] = date("Y-m-d H:i:s");
  50. $data["updateUser"] = session("user")["uid"];
  51. return IntegralProject::update($data);
  52. } else {
  53. $data["createTime"] = date("Y-m-d H:i:s");
  54. $data["createUser"] = session("user")["uid"];
  55. return IntegralProject::insert($data);
  56. }
  57. }
  58. public static function delete($id) {
  59. $data["id"] = $id;
  60. $data["delete"] = 1;
  61. $data["updateUser"] = session("user")["uid"];
  62. $data["updateTime"] = date("Y-m-d H:i:s");
  63. //同时删除子项
  64. $upd["delete"] = 1;
  65. $upd["updateTime"] = date("Y-m-d H:i:s");
  66. $upd["updateTime"] = session("user")["uid"];
  67. $where[] = ["projectId", "=", $id];
  68. \app\common\model\IntegralItem::where($where)->save($upd);
  69. return IntegralProject::update($data);
  70. }
  71. public static function chkExist($name, $type, $projectType, $id = 0) {
  72. $where = [];
  73. $where[] = ["type", "=", $type];
  74. $where[] = ["projectType", "=", $projectType];
  75. $where[] = ["name", "=", $name];
  76. $where[] = ["delete", "=", 0];
  77. if ($id) {
  78. $where[] = ["id", "<>", $id];
  79. }
  80. return IntegralProject::where($where)->find();
  81. }
  82. }