SiteAlbum.php 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?php
  2. namespace App\Admin\Repositories;
  3. use App\Models\SiteAlbum as Model;
  4. use Dcat\Admin\Repositories\EloquentRepository;
  5. class SiteAlbum extends EloquentRepository
  6. {
  7. /**
  8. * Model.
  9. *
  10. * @var string
  11. */
  12. protected $eloquentClass = Model::class;
  13. public static function siteAlbumPaginate($filter = [],$sort = [],$perPage = 15,$page = 1)
  14. {
  15. $siteAlbum = new Model();
  16. //筛选条件排除IDS
  17. $notInIds = isset($filter['not_in_ids'])? $filter['not_in_ids'] : [];
  18. if (!empty($notInIds)) {
  19. $notInIds = explode(',', $notInIds);
  20. $siteAlbum = $siteAlbum->whereNotIn('id', $notInIds);
  21. }
  22. //中文标题搜索
  23. $title = isset($filter['title'])? $filter['title'] : '';
  24. if ($title) {
  25. $siteAlbum = $siteAlbum->where('title', 'like', '%'. $title. '%');
  26. }
  27. //英文标题搜索
  28. $title_en = isset($filter['title_en'])? $filter['title_en'] : '';
  29. if ($title_en) {
  30. $siteAlbum = $siteAlbum->where('title_en', 'like', '%'. $title_en. '%');
  31. }
  32. //
  33. $filterModel = isset($filter['model'])? $filter['model'] : '';
  34. if ($filterModel) {
  35. $siteAlbum = $siteAlbum->where('model', 'like', '%'. $filterModel. '%');
  36. }
  37. //文件夹搜索
  38. $folder_id = isset($filter['folder_id'])? $filter['folder_id'] : '';
  39. if ($folder_id) {
  40. $siteAlbum = $siteAlbum->where('folder_id', $folder_id);
  41. }
  42. $albumFolder = isset($filter['album_folder'])? $filter['album_folder'] : -1;
  43. if ($albumFolder != -1) {
  44. $siteAlbum = $siteAlbum->whereIn('folder_id', $albumFolder);
  45. }
  46. //排序
  47. if (empty($sort)) {
  48. $siteAlbum = $siteAlbum->orderBy('id', 'desc');
  49. } else {
  50. $siteAlbum = $siteAlbum->orderBy($sort[0], $sort[1]);
  51. }
  52. $result = $siteAlbum->paginate(
  53. $perPage, $columns = ['*'], $pageName = 'page', $page
  54. );
  55. return $result;
  56. }
  57. public static function getByFolderId($id)
  58. {
  59. $siteAlbum = new Model();
  60. $result = $siteAlbum->where('folder_id', $id)->first();
  61. return $result;
  62. }
  63. }