list.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <?php
  2. ob_start();
  3. ?>
  4. <div class="min-h-screen bg-gray-50 py-6">
  5. <div class="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8">
  6. <!-- Header -->
  7. <div class="md:flex md:items-center md:justify-between mb-8">
  8. <div class="flex-1 min-w-0">
  9. <h2 class="text-2xl font-bold leading-7 text-gray-900 sm:text-3xl sm:truncate">
  10. Author Management
  11. </h2>
  12. <p class="mt-1 text-sm text-gray-500">
  13. Manage authors and their social media profiles
  14. </p>
  15. </div>
  16. <div class="mt-4 flex md:mt-0 md:ml-4">
  17. <a href="/admin/authors/?action=create"
  18. class="ml-3 inline-flex items-center px-4 py-2 border border-transparent rounded-md shadow-sm text-sm font-medium text-white bg-blue-600 hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 transition-colors">
  19. <svg class="w-5 h-5 mr-2" fill="currentColor" viewBox="0 0 20 20">
  20. <path fill-rule="evenodd" d="M10 3a1 1 0 011 1v5h5a1 1 0 110 2h-5v5a1 1 0 11-2 0v-5H4a1 1 0 110-2h5V4a1 1 0 011-1z" clip-rule="evenodd"/>
  21. </svg>
  22. Add New Author
  23. </a>
  24. </div>
  25. </div>
  26. <!-- Success/Error Messages -->
  27. <?php if (isset($success)): ?>
  28. <div class="mb-6 bg-green-50 border border-green-200 rounded-md p-4">
  29. <div class="flex">
  30. <div class="flex-shrink-0">
  31. <svg class="h-5 w-5 text-green-400" viewBox="0 0 20 20" fill="currentColor">
  32. <path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zm3.707-9.293a1 1 0 00-1.414-1.414L9 10.586 7.707 9.293a1 1 0 00-1.414 1.414l2 2a1 1 0 001.414 0l4-4z" clip-rule="evenodd"/>
  33. </svg>
  34. </div>
  35. <div class="ml-3">
  36. <p class="text-sm font-medium text-green-800"><?= htmlspecialchars($success) ?></p>
  37. </div>
  38. </div>
  39. </div>
  40. <?php endif; ?>
  41. <?php if (isset($error)): ?>
  42. <div class="mb-6 bg-red-50 border border-red-200 rounded-md p-4">
  43. <div class="flex">
  44. <div class="flex-shrink-0">
  45. <svg class="h-5 w-5 text-red-400" viewBox="0 0 20 20" fill="currentColor">
  46. <path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zM8.707 7.293a1 1 0 00-1.414 1.414L8.586 10l-1.293 1.293a1 1 0 101.414 1.414L10 11.414l1.293 1.293a1 1 0 001.414-1.414L11.414 10l1.293-1.293a1 1 0 00-1.414-1.414L10 8.586 8.707 7.293z" clip-rule="evenodd"/>
  47. </svg>
  48. </div>
  49. <div class="ml-3">
  50. <p class="text-sm font-medium text-red-800"><?= htmlspecialchars($error) ?></p>
  51. </div>
  52. </div>
  53. </div>
  54. <?php endif; ?>
  55. <!-- Authors Table -->
  56. <div class="bg-white shadow overflow-hidden sm:rounded-md">
  57. <div class="px-4 py-5 sm:px-6 border-b border-gray-200">
  58. <h3 class="text-lg leading-6 font-medium text-gray-900">All Authors</h3>
  59. <p class="mt-1 max-w-2xl text-sm text-gray-500">A list of all authors in the system.</p>
  60. </div>
  61. <?php if (empty($authors)): ?>
  62. <div class="text-center py-12">
  63. <svg class="mx-auto h-12 w-12 text-gray-400" stroke="currentColor" fill="none" viewBox="0 0 48 48">
  64. <path d="M28 8H12a4 4 0 00-4 4v20m32-12v8m0 0v8a4 4 0 01-4 4H12a4 4 0 01-4-4v-4m32-4l-3.172-3.172a4 4 0 00-5.656 0L28 28M8 32l9.172-9.172a4 4 0 015.656 0L28 28m0 0l4 4m4-24h8m-4-4v8m-12 4h.02" stroke-linecap="round" stroke-linejoin="round" stroke-width="2"/>
  65. </svg>
  66. <h3 class="mt-2 text-sm font-medium text-gray-900">No authors</h3>
  67. <p class="mt-1 text-sm text-gray-500">Get started by creating a new author.</p>
  68. <div class="mt-6">
  69. <a href="/admin/authors/?action=create" class="inline-flex items-center px-4 py-2 border border-transparent shadow-sm text-sm font-medium rounded-md text-white bg-blue-600 hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500">
  70. <svg class="w-5 h-5 mr-2" fill="currentColor" viewBox="0 0 20 20">
  71. <path fill-rule="evenodd" d="M10 3a1 1 0 011 1v5h5a1 1 0 110 2h-5v5a1 1 0 11-2 0v-5H4a1 1 0 110-2h5V4a1 1 0 011-1z" clip-rule="evenodd"/>
  72. </svg>
  73. Add Author
  74. </a>
  75. </div>
  76. </div>
  77. <?php else: ?>
  78. <div class="overflow-x-auto">
  79. <table class="min-w-full divide-y divide-gray-200">
  80. <thead class="bg-gray-50">
  81. <tr>
  82. <th scope="col" class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
  83. Author
  84. </th>
  85. <th scope="col" class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
  86. Description
  87. </th>
  88. <th scope="col" class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
  89. Social Links
  90. </th>
  91. <th scope="col" class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
  92. Created
  93. </th>
  94. <th scope="col" class="relative px-6 py-3">
  95. <span class="sr-only">Actions</span>
  96. </th>
  97. </tr>
  98. </thead>
  99. <tbody class="bg-white divide-y divide-gray-200">
  100. <?php foreach ($authors as $author): ?>
  101. <tr class="hover:bg-gray-50">
  102. <td class="px-6 py-4 whitespace-nowrap">
  103. <div class="flex items-center">
  104. <?php if (!empty($author['image'])): ?>
  105. <div class="flex-shrink-0 h-10 w-10">
  106. <img class="h-10 w-10 rounded-full object-cover" src="/<?= htmlspecialchars($author['image']) ?>" alt="<?= htmlspecialchars($author['name']) ?>">
  107. </div>
  108. <?php else: ?>
  109. <div class="flex-shrink-0 h-10 w-10 bg-gray-300 rounded-full flex items-center justify-center">
  110. <svg class="h-6 w-6 text-gray-500" fill="none" stroke="currentColor" viewBox="0 0 24 24">
  111. <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"/>
  112. </svg>
  113. </div>
  114. <?php endif; ?>
  115. <div class="ml-4">
  116. <div class="text-sm font-medium text-gray-900"><?= htmlspecialchars($author['name']) ?></div>
  117. </div>
  118. </div>
  119. </td>
  120. <td class="px-6 py-4">
  121. <div class="text-sm text-gray-900 max-w-xs truncate">
  122. <?= htmlspecialchars($author['description'] ?? 'No description') ?>
  123. </div>
  124. </td>
  125. <td class="px-6 py-4 whitespace-nowrap">
  126. <div class="flex space-x-2">
  127. <?php if (!empty($author['social_links'])): ?>
  128. <?php foreach ($author['social_links'] as $link): ?>
  129. <a href="<?= htmlspecialchars($link['url']) ?>" target="_blank"
  130. class="text-blue-600 hover:text-blue-800 text-sm">
  131. <?= htmlspecialchars($link['platform']) ?>
  132. </a>
  133. <?php endforeach; ?>
  134. <?php else: ?>
  135. <span class="text-gray-400 text-sm">No links</span>
  136. <?php endif; ?>
  137. </div>
  138. </td>
  139. <td class="px-6 py-4 whitespace-nowrap text-sm text-gray-500">
  140. <?= date('M j, Y', strtotime($author['created_at'])) ?>
  141. </td>
  142. <td class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium">
  143. <div class="flex items-center justify-end space-x-2">
  144. <a href="/admin/authors/?action=edit&id=<?= $author['id'] ?>"
  145. class="text-blue-600 hover:text-blue-900 font-medium">Edit</a>
  146. <form method="POST" class="inline" onsubmit="return confirm('Are you sure you want to delete this author?');">
  147. <input type="hidden" name="action" value="delete">
  148. <input type="hidden" name="id" value="<?= $author['id'] ?>">
  149. <button type="submit" class="text-red-600 hover:text-red-900 font-medium ml-2">Delete</button>
  150. </form>
  151. </div>
  152. </td>
  153. </tr>
  154. <?php endforeach; ?>
  155. </tbody>
  156. </table>
  157. </div>
  158. <?php endif; ?>
  159. </div>
  160. </div>
  161. </div>
  162. <?php
  163. $content = ob_get_clean();
  164. include __DIR__ . '/../partials/layout.php';
  165. ?>