pro-logged-in.blade.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <title>Stag | Pro</title>
  7. <!-- Tell the browser to be responsive to screen width -->
  8. <meta name="viewport" content="width=device-width, initial-scale=1">
  9. <!-- Font Awesome -->
  10. <link rel="stylesheet" href="/AdminLTE-3.0.5/plugins/fontawesome-free/css/all.min.css">
  11. <!-- Ionicons -->
  12. <link rel="stylesheet" href="https://code.ionicframework.com/ionicons/2.0.1/css/ionicons.min.css">
  13. <!-- Tempusdominus Bbootstrap 4 -->
  14. <link rel="stylesheet" href="/AdminLTE-3.0.5/plugins/tempusdominus-bootstrap-4/css/tempusdominus-bootstrap-4.min.css">
  15. <!-- iCheck -->
  16. <link rel="stylesheet" href="/AdminLTE-3.0.5/plugins/icheck-bootstrap/icheck-bootstrap.min.css">
  17. <!-- JQVMap -->
  18. <link rel="stylesheet" href="/AdminLTE-3.0.5/plugins/jqvmap/jqvmap.min.css">
  19. <!-- Theme style -->
  20. <link rel="stylesheet" href="/AdminLTE-3.0.5/dist/css/adminlte.min.css">
  21. <!-- overlayScrollbars -->
  22. <link rel="stylesheet" href="/AdminLTE-3.0.5/plugins/overlayScrollbars/css/OverlayScrollbars.min.css">
  23. <!-- Daterange picker -->
  24. <link rel="stylesheet" href="/AdminLTE-3.0.5/plugins/daterangepicker/daterangepicker.css">
  25. <!-- summernote -->
  26. <link rel="stylesheet" href="/AdminLTE-3.0.5/plugins/summernote/summernote-bs4.css">
  27. <!-- Google Font: Source Sans Pro -->
  28. <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,400,400i,700" rel="stylesheet">
  29. </head>
  30. <body class="hold-transition sidebar-mini layout-fixed">
  31. <div class="wrapper">
  32. <!-- Navbar -->
  33. <nav class="main-header navbar navbar-expand navbar-white navbar-light">
  34. <!-- Left navbar links -->
  35. <ul class="navbar-nav">
  36. <li class="nav-item">
  37. <a class="nav-link" data-widget="pushmenu" href="#" role="button"><i class="fas fa-bars"></i></a>
  38. </li>
  39. </ul>
  40. <!-- SEARCH FORM -->
  41. <form class="form-inline ml-3 w-25">
  42. <div class="input-group input-group-sm w-100">
  43. <input class="form-control form-control-navbar" type="search" placeholder="Search" aria-label="Search">
  44. <div class="input-group-append">
  45. <button class="btn btn-navbar" type="submit">
  46. <i class="fas fa-search"></i>
  47. </button>
  48. </div>
  49. </div>
  50. </form>
  51. <!-- Right navbar links -->
  52. <ul class="navbar-nav ml-auto">
  53. <li class="nav-item">
  54. <a class="nav-link" href="#" role="button">
  55. <i class="fas fa-sign-out-alt"></i>
  56. </a>
  57. </li>
  58. </ul>
  59. </nav>
  60. <!-- /.navbar -->
  61. <!-- Main Sidebar Container -->
  62. <aside class="main-sidebar sidebar-dark-primary elevation-4">
  63. <!-- Brand Logo -->
  64. <a href="/AdminLTE-3.0.5/index3.html" class="brand-link">
  65. <img src="/AdminLTE-3.0.5/dist/img/AdminLTELogo.png" alt="AdminLTE Logo" class="brand-image img-circle elevation-3"
  66. style="opacity: .8">
  67. <span class="brand-text font-weight-light">Stag | Pro</span>
  68. </a>
  69. <!-- Sidebar -->
  70. <div class="sidebar">
  71. <!-- Sidebar Menu -->
  72. <nav class="mt-2">
  73. <ul class="nav nav-pills nav-sidebar flex-column" data-widget="treeview" role="menu" data-accordion="false">
  74. <li class="nav-item">
  75. <a href="/pro/dashboard" class="nav-link">
  76. <i class="nav-icon fa fa-palette"></i>
  77. <p>
  78. Dashboard
  79. </p>
  80. </a>
  81. </li>
  82. <li class="nav-item">
  83. <a href="/pros" class="nav-link">
  84. <i class="nav-icon far fa-image"></i>
  85. <p>
  86. Pros
  87. </p>
  88. </a>
  89. </li>
  90. <!-- __SCAFFOLD_LINKS__ -->
  91. <!-- SCAF --><li class="nav-item"><a href="/my-teams" class="nav-link"><i class="nav-icon fa fa-user"></i><p>My Teams</p></a></li>
  92. <!-- SCAF --><li class="nav-item"><a href="/my-clients" class="nav-link"><i class="nav-icon fa fa-user"></i><p>My Clients</p></a></li>
  93. <!-- SCAF --><li class="nav-item"><a href="/notes" class="nav-link"><i class="nav-icon fa fa-user"></i><p>Notes</p></a></li>
  94. </ul>
  95. </nav>
  96. <!-- /.sidebar-menu -->
  97. </div>
  98. <!-- /.sidebar -->
  99. </aside>
  100. <!-- Content Wrapper. Contains page content -->
  101. <div class="content-wrapper">
  102. <!-- Main content -->
  103. <section class="content">
  104. <div class="container-fluid py-3">
  105. <div class="row mb-2">
  106. <div class="col-12">
  107. @yield('content')
  108. </div>
  109. </div>
  110. </div><!-- /.container-fluid -->
  111. </section>
  112. <!-- /.content -->
  113. </div>
  114. <div class="modal" id="incomingCallModal" tabindex="-1" role="dialog">
  115. <div class="modal-dialog" role="document">
  116. <div class="modal-content">
  117. <div class="modal-header">
  118. <h5 class="modal-title">Incoming Call</h5>
  119. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  120. <span aria-hidden="true">&times;</span>
  121. </button>
  122. </div>
  123. <div class="modal-body">
  124. <p>Click <b>Accept</b> to join the call.</p>
  125. </div>
  126. <div class="modal-footer">
  127. <button type="button" class="btn btn-success px-4" onclick="joinCall()">Answer</button>
  128. <button type="button" class="btn btn-secondary px-4" data-dismiss="modal">Reject</button>
  129. </div>
  130. </div>
  131. </div>
  132. </div>
  133. <script src="{{asset('js/moe.js')}}"></script>
  134. <script>
  135. var stompClient = null;
  136. function setConnected(connected) {
  137. console.log("User is connected");
  138. $("#connect").prop("disabled", connected);
  139. $("#disconnect").prop("disabled", !connected);
  140. if (connected) {
  141. $("#conversation").show();
  142. }
  143. else {
  144. $("#conversation").hide();
  145. }
  146. $("#greetings").html("");
  147. }
  148. function connect() {
  149. console.log("connecting...");
  150. var socket = new SockJS('http://localhost:8080/ws');
  151. stompClient = Stomp.over(socket);
  152. stompClient.connect({}, function (frame) {
  153. console.log("Connected");
  154. setConnected(true);
  155. console.log('Connected: ' + frame);
  156. // stompClient.send("/app/update-participant-status", {}, JSON.stringify({meetingUid:"mymeetinguid", status:'mystatus'}));
  157. // stompClient.subscribe('/user/topic/on-participant-status-change', function (message) {
  158. // console.log("Participant status changed: ", message);
  159. // });
  160. stompClient.subscribe("/user/topic/on-pro-incoming-call", function(message){
  161. console.log("incoming call:", message);
  162. message = JSON.parse(message.body);
  163. console.log(message.meetingUid);
  164. $('#incomingCallModal')
  165. .data('meetingUid', message.meetingUid)
  166. .modal('show');
  167. });
  168. // connect
  169. stompClient.send("/app/pro-connect", {}, JSON.stringify({sessionKey: "<?= request()->cookie('sessionKey') ?>"}));
  170. console.log('Pro connected')
  171. });
  172. }
  173. connect();
  174. function joinCall() {
  175. var modal = $('#incomingCallModal');
  176. window.location.href = '/pro/meeting/' +
  177. modal.data('meetingUid');
  178. }
  179. function disconnect() {
  180. if (stompClient !== null) {
  181. stompClient.disconnect();
  182. }
  183. setConnected(false);
  184. console.log("Disconnected");
  185. }
  186. function sendName() {
  187. stompClient.send("/app/hello", {}, JSON.stringify({'name': $("#name").val()}));
  188. }
  189. function showGreeting(message) {
  190. $("#greetings").append("<tr><td>" + message + "</td></tr>");
  191. }
  192. $(function () {
  193. $("form").on('submit', function (e) {
  194. e.preventDefault();
  195. });
  196. $( "#connect" ).click(function() { connect(); });
  197. $( "#disconnect" ).click(function() { disconnect(); });
  198. $( "#send" ).click(function() { sendName(); });
  199. });
  200. </script>
  201. </div>
  202. <!-- ./wrapper -->
  203. <!-- jQuery -->
  204. <script src="/AdminLTE-3.0.5/plugins/jquery/jquery.min.js"></script>
  205. <!-- jQuery UI 1.11.4 -->
  206. <script src="/AdminLTE-3.0.5/plugins/jquery-ui/jquery-ui.min.js"></script>
  207. <!-- Resolve conflict in jQuery UI tooltip with Bootstrap tooltip -->
  208. <script>
  209. $.widget.bridge('uibutton', $.ui.button)
  210. </script>
  211. <!-- Bootstrap 4 -->
  212. <script src="/AdminLTE-3.0.5/plugins/bootstrap/js/bootstrap.bundle.min.js"></script>
  213. <!-- ChartJS -->
  214. <script src="/AdminLTE-3.0.5/plugins/chart.js/Chart.min.js"></script>
  215. <!-- Sparkline -->
  216. <script src="/AdminLTE-3.0.5/plugins/sparklines/sparkline.js"></script>
  217. <!-- JQVMap -->
  218. <script src="/AdminLTE-3.0.5/plugins/jqvmap/jquery.vmap.min.js"></script>
  219. <script src="/AdminLTE-3.0.5/plugins/jqvmap/maps/jquery.vmap.usa.js"></script>
  220. <!-- jQuery Knob Chart -->
  221. <script src="/AdminLTE-3.0.5/plugins/jquery-knob/jquery.knob.min.js"></script>
  222. <!-- daterangepicker -->
  223. <script src="/AdminLTE-3.0.5/plugins/moment/moment.min.js"></script>
  224. <script src="/AdminLTE-3.0.5/plugins/daterangepicker/daterangepicker.js"></script>
  225. <!-- Tempusdominus Bootstrap 4 -->
  226. <script src="/AdminLTE-3.0.5/plugins/tempusdominus-bootstrap-4/js/tempusdominus-bootstrap-4.min.js"></script>
  227. <!-- Summernote -->
  228. <script src="/AdminLTE-3.0.5/plugins/summernote/summernote-bs4.min.js"></script>
  229. <!-- overlayScrollbars -->
  230. <script src="/AdminLTE-3.0.5/plugins/overlayScrollbars/js/jquery.overlayScrollbars.min.js"></script>
  231. <!-- AdminLTE App -->
  232. <script src="/AdminLTE-3.0.5/dist/js/adminlte.js"></script>
  233. <!-- AdminLTE dashboard demo (This is only for demo purposes) -->
  234. <script src="/AdminLTE-3.0.5/dist/js/pages/dashboard.js"></script>
  235. <!-- AdminLTE for demo purposes -->
  236. <script src="/AdminLTE-3.0.5/dist/js/demo.js"></script>
  237. </body>
  238. </html>