book-list.blade.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. {{-- resources/views/components/book-list.blade.php --}}
  2. @once
  3. @push('styles')
  4. <style>
  5. .book-list-container {
  6. max-width: 1024px;
  7. margin: 0 auto;
  8. padding: 20px;
  9. }
  10. .book-item {
  11. margin-bottom: 24px;
  12. transition: all 0.3s ease;
  13. }
  14. .book-item:hover {
  15. transform: translateY(-2px);
  16. box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  17. }
  18. .book-cover {
  19. width: 100%;
  20. aspect-ratio: 3/4;
  21. object-fit: contain !important;
  22. border-radius: 6px;
  23. background-color: #f8f9fa;
  24. }
  25. .book-info {
  26. padding: 16px 0;
  27. }
  28. .book-title {
  29. font-size: 1.125rem;
  30. font-weight: 600;
  31. color: #1f2937;
  32. margin-bottom: 8px;
  33. line-height: 1.4;
  34. }
  35. .book-author {
  36. color: #6b7280;
  37. font-size: 0.95rem;
  38. margin-bottom: 6px;
  39. }
  40. .book-language {
  41. color: #9ca3af;
  42. font-size: 0.875rem;
  43. }
  44. /* 桌面端布局 */
  45. @media (min-width: 576px) {
  46. .book-grid {
  47. display: grid;
  48. grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  49. gap: 24px;
  50. }
  51. }
  52. /* 手机端布局 */
  53. @media (max-width: 575px) {
  54. .book-item .card-body {
  55. display: flex;
  56. gap: 16px;
  57. align-items: stretch;
  58. }
  59. .book-cover-container {
  60. flex: 0 0 120px;
  61. }
  62. .book-cover {
  63. height: 160px;
  64. width: 120px;
  65. }
  66. .book-info {
  67. flex: 1;
  68. padding: 0;
  69. display: flex;
  70. flex-direction: column;
  71. justify-content: space-between;
  72. }
  73. .book-title {
  74. font-size: 1rem;
  75. margin-bottom: 12px;
  76. }
  77. }
  78. </style>
  79. @endpush
  80. @endonce
  81. <div>
  82. @if(!empty($books) && count($books) > 0)
  83. <div class="book-grid">
  84. @foreach($books as $book)
  85. @include('components.book-item', ['book' => $book])
  86. @endforeach
  87. </div>
  88. @else
  89. <div class="text-center py-5">
  90. <p class="text-muted">暂无图书数据</p>
  91. </div>
  92. @endif
  93. </div>