DhammaTermController.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  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. // validate
  68. // read more on validation at http://laravel.com/docs/validation
  69. $rules = array(
  70. 'word' => 'required',
  71. 'meaning' => 'required',
  72. 'language' => 'required'
  73. );
  74. $validator = Validator::make($request->all(), $rules);
  75. // process the login
  76. if ($validator->fails()) {
  77. return $this->error($validator);
  78. } else {
  79. #查询重复的
  80. $table = DhammaTerm::where('owner', $_COOKIE["user_uid"])
  81. ->where('word',$request->get("word"))
  82. ->where('tag',$request->get("tag"));
  83. if($request->get("channel")){
  84. $isDoesntExist = $table->where('channel',$request->get("channel"))
  85. ->doesntExist();
  86. }else{
  87. $isDoesntExist = $table->where('language',$request->get("language"))
  88. ->doesntExist();
  89. }
  90. if($isDoesntExist){
  91. #不存在插入数据
  92. $term = new DhammaTerm;
  93. $term->id=$snowflake->id();
  94. $term->guid=Str::uuid();
  95. $term->word=$request->get("word");
  96. $term->meaning=$request->get("meaning");
  97. $term->save();
  98. return $this->ok($data);
  99. }else{
  100. return $this->error("word existed");
  101. }
  102. // store
  103. /*
  104. $data = $request->all();
  105. $data['id'] = $snowflake->id();
  106. $data['guid'] = Str::uuid();
  107. DhammaTerm::create($data);
  108. */
  109. }
  110. }
  111. /**
  112. * Display the specified resource.
  113. *
  114. * @param \App\Models\DhammaTerm $dhammaTerm
  115. * @return \Illuminate\Http\Response
  116. */
  117. public function show(DhammaTerm $dhammaTerm)
  118. {
  119. //
  120. }
  121. /**
  122. * Update the specified resource in storage.
  123. *
  124. * @param \Illuminate\Http\Request $request
  125. * @param \App\Models\DhammaTerm $dhammaTerm
  126. * @return \Illuminate\Http\Response
  127. */
  128. public function update(Request $request, DhammaTerm $dhammaTerm)
  129. {
  130. //
  131. }
  132. /**
  133. * Remove the specified resource from storage.
  134. *
  135. * @param \App\Models\DhammaTerm $dhammaTerm
  136. * @return \Illuminate\Http\Response
  137. */
  138. public function destroy(DhammaTerm $dhammaTerm,Request $request)
  139. {
  140. //
  141. $arrId = json_decode($request->get("id"),true) ;
  142. $count = 0;
  143. foreach ($arrId as $key => $id) {
  144. # code...
  145. $result = DhammaTerm::where('id', $id)
  146. ->where('owner', $_COOKIE["user_uid"])
  147. ->delete();
  148. if($result){
  149. $count++;
  150. }
  151. }
  152. return $this->ok($count);
  153. }
  154. }