DhammaTermController.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\DhammaTerm;
  4. use Illuminate\Http\Request;
  5. class DhammaTermController extends Controller
  6. {
  7. /**
  8. * Display a listing of the resource.
  9. *
  10. * @return \Illuminate\Http\Response
  11. */
  12. public function index(Request $request)
  13. {
  14. $result=false;
  15. $indexCol = ['id','guid','word','word_en','meaning','other_meaning','note','language','channal','updated_at'];
  16. switch ($request->get('view')) {
  17. case 'user':
  18. # code...
  19. $userUid = $_COOKIE['user_uid'];
  20. $search = $request->get('search');
  21. $table = DhammaTerm::select($indexCol)
  22. ->where('owner', $userUid);
  23. if(!empty($search)){
  24. $table->where('word', 'like', $search."%")
  25. ->orWhere('word_en', 'like', $search."%")
  26. ->orWhere('meaning', 'like', "%".$search."%");
  27. }
  28. if(!empty($request->get('order')) && !empty($request->get('dir'))){
  29. $table->orderBy($request->get('order'),$request->get('dir'));
  30. }else{
  31. $table->orderBy('updated_at','desc');
  32. }
  33. $count = $table->count();
  34. if(!empty($request->get('limit'))){
  35. $offset = 0;
  36. if(!empty($request->get("offset"))){
  37. $offset = $request->get("offset");
  38. }
  39. $table->skip($offset)->take($request->get('limit'));
  40. }
  41. $result = $table->get();
  42. break;
  43. case 'word':
  44. $result = DhammaTerm::select($indexCol)
  45. ->where('word', $request->get("word"))
  46. ->orderBy('created_at','desc')
  47. ->get();
  48. break;
  49. default:
  50. # code...
  51. break;
  52. }
  53. if($result){
  54. return $this->ok(["rows"=>$result,"count"=>$count]);
  55. }else{
  56. return $this->error("没有查询到数据");
  57. }
  58. }
  59. /**
  60. * Store a newly created resource in storage.
  61. *
  62. * @param \Illuminate\Http\Request $request
  63. * @return \Illuminate\Http\Response
  64. */
  65. public function store(Request $request)
  66. {
  67. //
  68. }
  69. /**
  70. * Display the specified resource.
  71. *
  72. * @param \App\Models\DhammaTerm $dhammaTerm
  73. * @return \Illuminate\Http\Response
  74. */
  75. public function show(DhammaTerm $dhammaTerm)
  76. {
  77. //
  78. }
  79. /**
  80. * Update the specified resource in storage.
  81. *
  82. * @param \Illuminate\Http\Request $request
  83. * @param \App\Models\DhammaTerm $dhammaTerm
  84. * @return \Illuminate\Http\Response
  85. */
  86. public function update(Request $request, DhammaTerm $dhammaTerm)
  87. {
  88. //
  89. }
  90. /**
  91. * Remove the specified resource from storage.
  92. *
  93. * @param \App\Models\DhammaTerm $dhammaTerm
  94. * @return \Illuminate\Http\Response
  95. */
  96. public function destroy(DhammaTerm $dhammaTerm,Request $request)
  97. {
  98. //
  99. $arrId = json_decode($request->get("id"),true) ;
  100. $count = 0;
  101. foreach ($arrId as $key => $id) {
  102. # code...
  103. $result = DhammaTerm::where('id', $id)
  104. ->where('owner', $_COOKIE["user_uid"])
  105. ->delete();
  106. if($result){
  107. $count++;
  108. }
  109. }
  110. return $this->ok($count);
  111. }
  112. }