DictPreferenceController.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Support\Facades\Log;
  4. use Illuminate\Http\Request;
  5. use App\Models\UserDict;
  6. use App\Models\WordIndex;
  7. use App\Http\Resources\DictPreferenceResource;
  8. use App\Http\Api\DictApi;
  9. use App\Http\Api\AuthApi;
  10. class DictPreferenceController extends Controller
  11. {
  12. /**
  13. * Display a listing of the resource.
  14. *
  15. * @return \Illuminate\Http\Response
  16. */
  17. public function index(Request $request)
  18. {
  19. //
  20. $dict_id = DictApi::getSysDict('system_preference');
  21. if (!$dict_id) {
  22. return $this->error('没有找到 system_preference 字典', 200, 200);
  23. }
  24. $table = WordIndex::where('user_dicts.dict_id', $dict_id)
  25. ->leftJoin('user_dicts', 'word_indices.word', '=', 'user_dicts.word')
  26. ->select([
  27. 'user_dicts.id',
  28. 'word_indices.word',
  29. 'word_indices.count',
  30. 'user_dicts.factors',
  31. 'user_dicts.parent',
  32. 'user_dicts.note',
  33. 'user_dicts.confidence',
  34. 'user_dicts.editor_id',
  35. ]);
  36. //处理搜索
  37. if (!empty($request->get("keyword"))) {
  38. $table = $table->where('word_indices.word', 'like', "%" . $request->get("keyword") . "%");
  39. }
  40. //获取记录总条数
  41. $count = $table->count();
  42. //处理排序
  43. $table = $table->orderBy(
  44. $request->get("order", 'word_indices.count'),
  45. $request->get("dir", 'desc')
  46. );
  47. //处理分页
  48. $table = $table->skip($request->get("offset", 0))
  49. ->take($request->get("limit", 200));
  50. //获取数据
  51. $result = $table->get();
  52. return $this->ok([
  53. "rows" => DictPreferenceResource::collection($result),
  54. "count" => $count
  55. ]);
  56. }
  57. /**
  58. * Store a newly created resource in storage.
  59. *
  60. * @param \Illuminate\Http\Request $request
  61. * @return \Illuminate\Http\Response
  62. */
  63. public function store(Request $request)
  64. {
  65. //
  66. }
  67. /**
  68. * Display the specified resource.
  69. *
  70. * @param \App\Models\UserDict $userDict
  71. * @return \Illuminate\Http\Response
  72. */
  73. public function show(UserDict $userDict)
  74. {
  75. //
  76. }
  77. /**
  78. * Update the specified resource in storage.
  79. *
  80. * @param \Illuminate\Http\Request $request
  81. * @param string $id
  82. * @return \Illuminate\Http\Response
  83. */
  84. public function update(Request $request, $id)
  85. {
  86. $user = AuthApi::current($request);
  87. if (!$user) {
  88. return $this->error(__('auth.failed'), [], 401);
  89. }
  90. $newData = $request->all();
  91. $word = UserDict::findOrFail($id);
  92. if (isset($newData['factors'])) {
  93. $word->factors = $newData['factors'];
  94. }
  95. if (isset($newData['parent'])) {
  96. $word->parent = $newData['parent'];
  97. }
  98. if (isset($newData['confidence'])) {
  99. $word->confidence = $newData['confidence'];
  100. }
  101. $word->editor_id = $user['user_uid'];
  102. $word->save();
  103. return $this->ok(new DictPreferenceResource($word));
  104. }
  105. /**
  106. * Remove the specified resource from storage.
  107. *
  108. * @param \App\Models\UserDict $userDict
  109. * @return \Illuminate\Http\Response
  110. */
  111. public function destroy(UserDict $userDict)
  112. {
  113. //
  114. }
  115. }