book-list.blade.php 2.5 KB

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