You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

279 lines
10 KiB

6 years ago
6 years ago
6 years ago
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
  5. <script src="socket.io/node_modules/socket.io-client/dist/socket.io.js"></script>
  6. <title>Denunciation Map</title>
  7. <meta name="viewport" content="initial-scale=1.0">
  8. <meta charset="utf-8">
  9. <style>
  10. #map {
  11. height: 100%;
  12. }
  13. html, body {
  14. height: 100%;
  15. margin: 0;
  16. padding: 0;
  17. }
  18. </style>
  19. <style>
  20. #img:hover{
  21. color: #424242;
  22. -webkit-transition: all .3s ease-in;
  23. -moz-transition: all .3s ease-in;
  24. -ms-transition: all .3s ease-in;
  25. -o-transition: all .3s ease-in;
  26. transition: all .3s ease-in;
  27. opacity: 1;
  28. transform: scale(1.15);
  29. -ms-transform: scale(1.15); /* IE 9 */
  30. -webkit-transform: scale(1.15); /* Safari and Chrome */
  31. max-width: 400px;
  32. max-height: 400px;
  33. }
  34. #img-user{
  35. max-width: 150px;
  36. max-height: 150px;
  37. }
  38. .title{
  39. text-align: left;
  40. }
  41. td{
  42. padding: 20px 10px;
  43. }
  44. .popup{
  45. display: none; /* Hidden by default */
  46. position: fixed; /* Stay in place */
  47. left: 0;
  48. top: 0;
  49. width: 100%; /* Full width */
  50. height: 100%; /* Full height */
  51. overflow: auto; /* Enable scroll if needed */
  52. background-color: rgb(0,0,0); /* Fallback color */
  53. background-color: rgba(0,0,0,0.4); /* Black w/ opacity */
  54. padding-top: 60px;
  55. }
  56. #table,#table-user{
  57. background: white;
  58. padding: 40px 60px;
  59. }
  60. #content, #user-content{
  61. display: inline-block;
  62. margin-top: 125px;
  63. background: white;
  64. }
  65. </style>
  66. </head>
  67. <body>
  68. <audio id="audio" src="http://www.soundjay.com/button/beep-07.wav" autoplay="false"></audio>
  69. <div id="map"></div>
  70. <!-- ANANA SOKIYIM JAVASCRIPT
  71. Sen nası gereksiz bir dilsin amk bütün bi gecemi yedin
  72. ben senenin ebeni sikiyim inşallah seni yazan programcının götüne av tüfeği girer
  73. AYNISI SOCKET.IO IÇIN DE GEÇERLİ ALLAHIM KAFAYI YİCEM ADAMLAR HERALDE "ACABA NE KADAR ÖZÜRLÜ BI FRAMERWORK YAZARIZ DUYE BAŞLAMIŞLAR IŞE"-->
  74. <div id = "popup" align = "center" class = "popup">
  75. <div id = "content">
  76. <table border="0" cellpadding="10" cellspacing="0" id = "table" class = "modal">
  77. <tr>
  78. <td rowspan="2" colspan="7"><img src="cityscape.png" alt="img"id = "img"></td>
  79. <td colspan="2" class="title"><strong>Priority: </strong></td>
  80. <td colspan="1" id = "priority">7</td>
  81. </tr>
  82. <tr>
  83. <td colspan="2" class="title"><strong>Type: </strong></td>
  84. <td colspan="1" id = "type"> Ambulance</td>
  85. </tr>
  86. <tr>
  87. <td colspan="4" class="title"><strong>Submitter: </strong></td>
  88. <td colspan="6">
  89. <a href="#" id = "user" class = "panel" onclick=
  90. "document.getElementById('popup').style.display='none';
  91. document.getElementById('user-popup').style.display='block';
  92. setUser(this.getAttribute('userid'))"
  93. >Efe Aydın </a>
  94. </td>
  95. </tr>
  96. <tr>
  97. <td colspan="4" class="title"><strong>Message: </strong></td>
  98. <td colspan="6" id = "message">Test ambulance</td>
  99. </tr>
  100. <tr>
  101. <td colspan="4" class="title"><strong>Tags: </strong></td>
  102. <td colspan="6" id = "tags">Test tags</td>
  103. </tr>
  104. </table>
  105. </div>
  106. </div>
  107. <div id = "user-popup" align = "center" class="popup">
  108. <div id = "user-content">
  109. <table border="0" cellpadding="10" cellspacing="0" id = "table-user" class = "modal">
  110. <tr>
  111. <td rowspan="3" colspan="7"><img src="cityscape.png" alt="img"id = "img-user"></td>
  112. <td colspan="2" class="title"><strong>Name: </strong></td>
  113. <td colspan="1" id = "name">Efe Aydın</td>
  114. </tr>
  115. <tr>
  116. <td colspan="2" class="title"><strong>TC: </strong></td>
  117. <td colspan="1" id = "tc">111111111111</td>
  118. </tr>
  119. <tr>
  120. <td colspan="2" class="title"><strong>Trust: </strong></td>
  121. <td colspan="1" id = "trust">7</td>
  122. </tr>
  123. <tr>
  124. <td colspan="4" class="title"><strong>Phone: </strong></td>
  125. <td colspan="6" id="phone">
  126. 0 555 555 55 55
  127. </td>
  128. </tr>
  129. <tr>
  130. <td colspan="4" class="title"><strong>E-mail: </strong></td>
  131. <td colspan="6" id = "email">efeaydin@citizenview.com</td>
  132. </tr>
  133. <tr>
  134. <td colspan="4" class="title"><strong>Health: </strong></td>
  135. <td colspan="6" id = "health">Test tags</td>
  136. </tr>
  137. </table>
  138. <button onclick=
  139. "document.getElementById('popup').style.display='block';
  140. document.getElementById('user-popup').style.display='none';"
  141. style="margin-bottom: 5px;">OK</button>
  142. </div>
  143. </div>
  144. <script>
  145. function setUser(id) {
  146. if(!(id in users)) {
  147. $.get("https://" + document.domain + ":5000/users/" + id, function (dataStr, status) {
  148. data_user = $.parseJSON(dataStr)
  149. users[id]=data_user
  150. document.getElementById("name").innerHTML = users[id]["realname"];
  151. document.getElementById("tc").innerHTML = users[id]["TC"];
  152. document.getElementById("trust").innerHTML = users[id]["trustability"];
  153. document.getElementById("phone").innerHTML = users[id]["tel"];
  154. document.getElementById("email").innerHTML = users[id]["email"];
  155. document.getElementById("img-user").setAttribute("src","https://" + document.domain + ":5000"+users[id]["avatar"])
  156. });
  157. }else {
  158. document.getElementById("name").innerHTML = users[id]["realname"];
  159. document.getElementById("tc").innerHTML = users[id]["TC"];
  160. document.getElementById("trust").innerHTML = users[id]["trustability"];
  161. document.getElementById("phone").innerHTML = users[id]["tel"];
  162. document.getElementById("email").innerHTML = users[id]["email"];
  163. document.getElementById("img-user").setAttribute("src","https://" + document.domain + ":5000" + users[id]["avatar"])
  164. }
  165. }
  166. </script>
  167. <script>
  168. var modal = document.getElementById('popup');
  169. window.onclick = function(event) {
  170. if (event.target == modal) {
  171. modal.style.display = "none";
  172. }
  173. }
  174. </script>
  175. <script>
  176. var map;
  177. function initMap() {
  178. map = new google.maps.Map(document.getElementById('map'), {
  179. center: {lat: 39.92, lng: 32.85},
  180. zoom: 13
  181. });
  182. }
  183. </script>
  184. <script>
  185. var sound = document.getElementById("audio");
  186. var markers = [];
  187. var denunciation_count = markers.length;
  188. var socket = io.connect('http://' + document.domain + ':' + location.port + "/denunciations_socket");
  189. console.log('http://' + document.domain + ":4000/denunciations_socket")
  190. console.log(socket);
  191. var markers = [];
  192. var denunciation_count = markers.length;
  193. var users = {};
  194. setInterval(function () {
  195. socket.emit("check",{})
  196. },1000);
  197. socket.on("new",function (dataStr) {
  198. for (var i = 0; i < markers.length; i++) {
  199. markers.pop().setMap(null);
  200. }
  201. console.log("Update received!")
  202. data = $.parseJSON(dataStr);
  203. data.forEach(function(element) {
  204. var marker = new google.maps.Marker({
  205. position: { lat: element["location"]["latitude"], lng: element["location"]["longitude"]},
  206. map: map,
  207. label: element["priority"].toString(),
  208. title: element["info"]
  209. });
  210. marker.addListener('click', function() {
  211. document.getElementById('popup').style.display='block';
  212. document.getElementById("priority").innerHTML = element["priority"];
  213. document.getElementById("type").innerHTML = element["emergency"];
  214. document.getElementById("message").innerHTML = element["info"];
  215. if(!(element["reporter"] in users)) {
  216. $.get("https://" + document.domain + ":5000/users/" + element["reporter"], function (dataStr, status) {
  217. data_user = $.parseJSON(dataStr)
  218. users[element["reporter"]]=data_user
  219. document.getElementById("user").innerHTML = users[element["reporter"]]["realname"];
  220. });
  221. }else {
  222. document.getElementById("user").innerHTML = users[element["reporter"]]["realname"];
  223. }
  224. document.getElementById("user").setAttribute("userid",element["reporter"]);
  225. document.getElementById("img").setAttribute("src","data:image/png;base64," + element["photo"])
  226. });
  227. markers.push(marker);
  228. });
  229. if (denunciation_count < markers.length) {
  230. sound.play();
  231. }
  232. denunciation_count = markers.length;
  233. });
  234. </script>
  235. <script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyBuOC03IHPA_6TPnfk18b0SAgD1uge4-dk&callback=initMap"
  236. async defer></script>
  237. </body>
  238. </html>