SiteAlbum.php 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  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. $title = isset($filter['title'])? $filter['title'] : '';
  17. if ($title) {
  18. $siteAlbum = $siteAlbum->where('title', 'like', '%'. $title. '%');
  19. }
  20. $title_en = isset($filter['title_en'])? $filter['title_en'] : '';
  21. if ($title_en) {
  22. $siteAlbum = $siteAlbum->where('title_en', 'like', '%'. $title_en. '%');
  23. }
  24. $filterModel = isset($filter['model'])? $filter['model'] : '';
  25. if ($filterModel) {
  26. $siteAlbum = $siteAlbum->where('model', 'like', '%'. $filterModel. '%');
  27. }
  28. $folder_id = isset($filter['folder_id'])? $filter['folder_id'] : '';
  29. if ($folder_id) {
  30. $siteAlbum = $siteAlbum->where('folder_id', $folder_id);
  31. }
  32. $albumFolder = isset($filter['album_folder'])? $filter['album_folder'] : -1;
  33. if ($albumFolder != -1) {
  34. $siteAlbum = $siteAlbum->whereIn('folder_id', $albumFolder);
  35. }
  36. if (empty($sort)) {
  37. $siteAlbum = $siteAlbum->orderBy('id', 'desc');
  38. } else {
  39. $siteAlbum = $siteAlbum->orderBy($sort[0], $sort[1]);
  40. }
  41. $result = $siteAlbum->paginate(
  42. $perPage, $columns = ['*'], $pageName = 'page', $page
  43. );
  44. return $result;
  45. }
  46. public static function getByFolderId($id)
  47. {
  48. $siteAlbum = new Model();
  49. $result = $siteAlbum->where('folder_id', $id)->first();
  50. return $result;
  51. }
  52. }