search.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. <?php
  2. include_once 'includes/config.php';
  3. include_once 'includes/ResultsProvider.php';
  4. if(isset($_GET['term'])){
  5. $term = $_GET['term'];
  6. }else{
  7. exit("You must enter a search term");
  8. }
  9. $type = isset($_GET["type"]) ? $_GET["type"] : "sites";
  10. $page = isset($_GET["page"]) ? $_GET["page"] : 1;
  11. $resultsProvider = new ResultsProvider($db);
  12. ?>
  13. <!DOCTYPE html>
  14. <html lang="en">
  15. <head>
  16. <meta charset="UTF-8">
  17. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  18. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  19. <title>Search results</title>
  20. <link rel="stylesheet" href="assets/css/jquery.fancybox.min.css">
  21. <link rel="stylesheet" type="text/css" href="assets/css/style.css">
  22. <script src="assets/js/jquery.min.js"></script>
  23. </head>
  24. <body>
  25. <div class="wrapper">
  26. <div class="header">
  27. <div class="headerContent">
  28. <div class="logoContainer">
  29. <a href="index.php">
  30. <img src="assets/images/logo.png">
  31. </a>
  32. </div>
  33. <div class="searchContainer">
  34. <form action="search.php" method="GET">
  35. <div class="searchBarContainer">
  36. <input type="hidden" name="type" value="<?php echo $type; ?>">
  37. <input class="searchBox" type="text" name="term" value="<?php echo $term; ?>" autocomplete="off">
  38. <button class="searchButton">
  39. <img src="assets/images/search.png">
  40. </button>
  41. </div>
  42. </form>
  43. </div>
  44. </div>
  45. <div class="tabsContainer">
  46. <ul class="tabList">
  47. <li class="<?php echo $type == 'sites' ? 'active' : '' ?>">
  48. <a href='<?php echo "search.php?term=$term&type=sites"; ?>'>
  49. Sites
  50. </a>
  51. </li>
  52. <li class="<?php echo $type == 'images' ? 'active' : '' ?>">
  53. <a href='<?php echo "search.php?term=$term&type=images"; ?>'>
  54. Images
  55. </a>
  56. </li>
  57. <li class="<?php echo $type == 'videos' ? 'active' : '' ?>">
  58. <a href="<?php echo "search.php?term=$term&type=videos"; ?>">Videos</a>
  59. </li>
  60. </ul>
  61. </div>
  62. </div>
  63. <div class="mainResultsSection">
  64. <?php
  65. $numResults = $resultsProvider->get_total_result($type,$term);
  66. echo "<p class='resultsCount'>$numResults results found</p>";
  67. $pageSize = 20;
  68. if($type=='sites'){
  69. echo $resultsProvider->site_html_result($page,$pageSize,$term);
  70. }
  71. if($type == 'images'){
  72. echo $resultsProvider->images_html_result($page,$pageSize,$term);
  73. }
  74. if($type == 'videos'){
  75. echo 'under dev';
  76. }
  77. ?>
  78. </div>
  79. <div class="paginationContainer">
  80. <div class="pageButtons">
  81. <div class="pageNumberContainer">
  82. <img src="assets/images/pageStart.png">
  83. </div>
  84. <?php
  85. $pagesToShow = 10;
  86. $numPages = ceil($numResults / $pageSize);
  87. $pagesLeft = min($pagesToShow, $numPages);
  88. $currentPage = $page - floor($pagesToShow / 2);
  89. if($currentPage < 1) {
  90. $currentPage = 1;
  91. }
  92. if($currentPage + $pagesLeft > $numPages + 1) {
  93. $currentPage = $numPages + 1 - $pagesLeft;
  94. }
  95. while($pagesLeft != 0 && $currentPage <= $numPages) {
  96. if($currentPage == $page) {
  97. echo "<div class='pageNumberContainer'>
  98. <img src='assets/images/pageSelected.png'>
  99. <span class='pageNumber'>$currentPage</span>
  100. </div>";
  101. }
  102. else {
  103. echo "<div class='pageNumberContainer'>
  104. <a href='search.php?term=$term&type=$type&page=$currentPage'>
  105. <img src='assets/images/page.png'>
  106. <span class='pageNumber'>$currentPage</span>
  107. </a>
  108. </div>";
  109. }
  110. $currentPage++;
  111. $pagesLeft--;
  112. }
  113. ?>
  114. <div class="pageNumberContainer">
  115. <img src="assets/images/pageEnd.png">
  116. </div>
  117. </div>
  118. </div>
  119. </div>
  120. </body>
  121. <script src="assets/js/jquery.fancybox.min.js"></script>
  122. <script src="assets/js/masonry.pkgd.min.js"></script>
  123. <script src="assets/js/script.js"></script>
  124. </html>