home.blade.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. @extends('admin.partial.template-full')
  2. @section('section')
  3. </div>
  4. <div class="header bg-primary pb-3 mt-n4">
  5. <div class="container-fluid">
  6. <div class="header-body">
  7. <div class="row align-items-center py-4">
  8. <div class="col-lg-6 col-7">
  9. <p class="display-1 text-white d-inline-block mb-0">Custom Emoji</p>
  10. </div>
  11. </div>
  12. <div class="row">
  13. <div class="col-xl-2 col-md-6">
  14. <div class="mb-3">
  15. <h5 class="text-light text-uppercase mb-0">Total Emoji</h5>
  16. <span class="text-white h2 font-weight-bold mb-0 human-size">{{$stats['total']}}</span>
  17. </div>
  18. </div>
  19. <div class="col-xl-2 col-md-6">
  20. <div class="mb-3">
  21. <h5 class="text-light text-uppercase mb-0">Total Active</h5>
  22. <span class="text-white h2 font-weight-bold mb-0 human-size">{{$stats['active']}}</span>
  23. </div>
  24. </div>
  25. <div class="col-xl-2 col-md-6">
  26. <div class="mb-3">
  27. <h5 class="text-light text-uppercase mb-0">Remote Emoji</h5>
  28. <span class="text-white h2 font-weight-bold mb-0 human-size">{{$stats['remote']}}</span>
  29. </div>
  30. </div>
  31. <div class="col-xl-2 col-md-6">
  32. <div class="mb-3">
  33. <h5 class="text-light text-uppercase mb-0">Duplicate Emoji</h5>
  34. <span class="text-white h2 font-weight-bold mb-0 human-size">{{$stats['duplicate']}}</span>
  35. </div>
  36. </div>
  37. <div class="col-xl-4 col-md-6">
  38. <a
  39. class="btn btn-dark btn-lg px-3 mb-1"
  40. href="/i/admin/custom-emoji/new">
  41. <i class="far fa-plus mr-1"></i>
  42. Add Custom Emoji
  43. </a>
  44. </div>
  45. </div>
  46. <div class="row">
  47. <div class="col-12 mt-2">
  48. <p class="font-weight-light text-white small mb-0">
  49. Stats are cached for 12 hours and may not reflect the latest data.<br /> To refresh the cache and view the most recent data, <a href="/i/admin/custom-emoji/home?cc=1" class="font-weight-bold text-white">click here</a>.
  50. </p>
  51. </div>
  52. </div>
  53. </div>
  54. </div>
  55. </div>
  56. <div class="container mt-5">
  57. <div class="row justify-content-center">
  58. <div class="col-12 col-md-6">
  59. <form method="get" class="mb-3" id="duplicate-form">
  60. <input type="hidden" name="sort" value="search">
  61. <input class="form-control rounded-pill" name="q" placeholder="Search by shortcode or domain name" value="{{request()->input('q')}}">
  62. @if($sort == 'search')
  63. <div class="custom-control custom-checkbox mt-1">
  64. <input type="checkbox" class="custom-control-input" id="showDuplicate" name="dups" value="1" onclick="document.getElementById('duplicate-form').submit()" {{ request()->has('dups') ? 'checked' : ''}}>
  65. <label class="custom-control-label" for="showDuplicate">Show duplicate results</label>
  66. </div>
  67. @endif
  68. </form>
  69. @if($sort != 'search')
  70. <ul class="nav nav-pills my-3 nav-fill">
  71. <li class="nav-item">
  72. <a class="nav-link {{$sort=='all'?'active':''}}" href="?sort=all">All</a>
  73. </li>
  74. <li class="nav-item">
  75. <a class="nav-link {{$sort=='local'?'active':''}}" href="?sort=local">Local</a>
  76. </li>
  77. <li class="nav-item">
  78. <a class="nav-link {{$sort=='remote'?'active':''}}" href="?sort=remote">Remote</a>
  79. </li>
  80. <li class="nav-item">
  81. <a class="nav-link {{$sort=='duplicates'?'active':''}}" href="?sort=duplicates">Duplicates</a>
  82. </li>
  83. <li class="nav-item">
  84. <a class="nav-link {{$sort=='disabled'?'active':''}}" href="?sort=disabled">Disabled</a>
  85. </li>
  86. </ul>
  87. @endif
  88. @if($sort == 'duplicates')
  89. <div class="alert alert-warning py-2 mt-4">
  90. <p class="mb-0">
  91. <i class="far fa-exclamation-triangle mr-2"></i> Duplicate emoji shortcodes can lead to unpredictible results
  92. </p>
  93. </div>
  94. @endif
  95. <div class="list-group">
  96. @foreach($emojis as $emoji)
  97. <div class="list-group-item">
  98. <div class="media align-items-center">
  99. <img src="{{url('storage/' . $emoji->media_path)}}" width="40" height="40" class="mr-3">
  100. <div class="media-body">
  101. <p class="font-weight-bold mb-0">{{ $emoji->shortcode }}</p>
  102. @if($emoji->domain != config('pixelfed.domain.app'))
  103. <p class="text-muted small mb-0">{{ $emoji->domain }}</p>
  104. @endif
  105. </div>
  106. @if($sort == 'duplicates')
  107. <a
  108. class="btn btn-primary rounded-pill btn-sm px-2 py-1 ml-3"
  109. href="/i/admin/custom-emoji/duplicates/{{$emoji->shortcode}}">
  110. View duplicates
  111. </a>
  112. {{-- <div class="ml-3 badge badge-info">Updated {{$emoji->updated_at->diffForHumans(null, true, true)}}</div> --}}
  113. @else
  114. <div class="ml-3 badge badge-info">Updated {{$emoji->updated_at->diffForHumans(null, true, true)}}</div>
  115. <form
  116. class="form-inline"
  117. action="/i/admin/custom-emoji/toggle-active/{{$emoji->id}}"
  118. method="post">
  119. @csrf
  120. <button
  121. type="submit"
  122. class="ml-3 btn btn-sm {{$emoji->disabled ? 'btn-danger' : 'btn-success'}}">
  123. {{$emoji->disabled ? 'Disabled' : 'Active' }}
  124. </button>
  125. </form>
  126. <button class="btn btn-danger px-2 py-1 ml-3 delete-emoji" data-id="{{$emoji->id}}">
  127. <i class="far fa-trash-alt"></i>
  128. </button>
  129. @endif
  130. </div>
  131. </div>
  132. @endforeach
  133. </div>
  134. <div class="d-flex justify-content-center mt-3">
  135. {{ $emojis->links() }}
  136. </div>
  137. </div>
  138. </div>
  139. </div>
  140. @endsection
  141. @push('scripts')
  142. <script type="text/javascript">
  143. $('.delete-emoji').click(function(i) {
  144. if(!window.confirm('Are you sure you want to delete this custom emoji?')) {
  145. return;
  146. }
  147. let id = i.currentTarget.getAttribute('data-id');
  148. axios.post('/i/admin/custom-emoji/delete/' + id)
  149. .then(res => {
  150. $(i.currentTarget).closest('.list-group-item').remove();
  151. })
  152. });
  153. </script>
  154. @endpush