high.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. 'use strict';
  2. var cur_call = null;
  3. var verto;
  4. var chatting_with = false;
  5. var callbacks = {
  6. onMessage: function(verto, dialog, msg, data) {
  7. console.error("msg ", msg);
  8. console.error("data ", data);
  9. switch (msg) {
  10. case $.verto.enum.message.pvtEvent:
  11. if (data.pvtData) {
  12. console.error("data.pvtData ", data.pvtData);
  13. switch (data.pvtData.action) {
  14. case "conference-liveArray-join":
  15. chatting_with = data.pvtData.chatID;
  16. $("#content").hide();
  17. $("#ask").hide();
  18. $("#br").hide();
  19. $("#backbtn").hide();
  20. $("#ext").hide();
  21. $("#extbtn").hide();
  22. $("#callbtn").hide();
  23. $("#cidname").hide();
  24. $("#hupbtn").show();
  25. $("#chatwin").show();
  26. $("#chatmsg").show();
  27. $("#chatsend").show();
  28. $("#webcam").show();
  29. $("#video1").show();
  30. break;
  31. case "conference-liveArray-part":
  32. $("#content").show();
  33. $("#ask").show();
  34. $("#ext").show();
  35. $("#extbtn").show();
  36. $("#cidname").hide();
  37. $("#callbtn").hide();
  38. $("#hupbtn").hide();
  39. $("#chatwin").hide();
  40. $("#chatmsg").hide();
  41. $("#chatsend").hide();
  42. $("#backbtn").hide();
  43. $("#webcam").hide();
  44. $("#video1").hide();
  45. cur_call = null;
  46. break;
  47. }
  48. }
  49. break;
  50. case $.verto.enum.message.info:
  51. var body = data.body;
  52. var from = data.from_msg_name || data.from;
  53. if (body.slice(-1) !== "\n") {
  54. body += "\n";
  55. }
  56. $('#chatwin')
  57. .append(from + ': ')
  58. .append(body)
  59. $('#chatwin').animate({"scrollTop": $('#chatwin')[0].scrollHeight}, "fast");
  60. break;
  61. default:
  62. break;
  63. }
  64. },
  65. onEvent: function(v, e) {
  66. console.error("GOT EVENT", e);
  67. },
  68. onDialogState: function(d) {
  69. if (!cur_call) {
  70. cur_call = d;
  71. }
  72. switch (d.state) {
  73. case $.verto.enum.state.hangup:
  74. $("#content").show();
  75. $("#ask").show();
  76. $("#ext").show();
  77. $("#extbtn").show();
  78. $("#cidname").hide();
  79. $("#callbtn").hide();
  80. $("#hupbtn").hide();
  81. $("#chatwin").hide();
  82. $("#chatmsg").hide();
  83. $("#chatsend").hide();
  84. $("#backbtn").hide();
  85. $("#webcam").hide();
  86. $("#video1").hide();
  87. cur_call = null;
  88. console.error("HANGUP");
  89. break;
  90. case $.verto.enum.state.destroy:
  91. $("#content").show();
  92. $("#ask").show();
  93. $("#ext").show();
  94. $("#extbtn").show();
  95. $("#cidname").hide();
  96. $("#callbtn").hide();
  97. $("#hupbtn").hide();
  98. $("#chatwin").hide();
  99. $("#chatmsg").hide();
  100. $("#chatsend").hide();
  101. $("#backbtn").hide();
  102. $("#webcam").hide();
  103. $("#video1").hide();
  104. cur_call = null;
  105. console.error("DESTROY");
  106. break;
  107. case $.verto.enum.state.active:
  108. $("#content").hide();
  109. $("#ask").hide();
  110. $("#br").hide();
  111. $("#backbtn").hide();
  112. $("#ext").hide();
  113. $("#extbtn").hide();
  114. $("#callbtn").hide();
  115. $("#cidname").hide();
  116. $("#hupbtn").show();
  117. $("#chatwin").show();
  118. $("#chatmsg").show();
  119. $("#chatsend").show();
  120. $("#webcam").show();
  121. $("#video1").show();
  122. console.error("ACTIVE");
  123. break;
  124. default:
  125. break;
  126. }
  127. },
  128. };
  129. function docall() {
  130. if (cur_call) {
  131. return;
  132. }
  133. cur_call = verto.newCall({
  134. destination_number: $("#ext").val(),
  135. caller_id_name: $("#cidname").val(),
  136. caller_id_number: $("#cidnumber").val(),
  137. useVideo: true,
  138. useStereo: false,
  139. useCamera: $("#usecamera").find(":selected").val(),
  140. useMic: $("#usemic").find(":selected").val()
  141. });
  142. }
  143. $("#callbtn").click(function() {
  144. if($("#cidname").val() ){
  145. docall();
  146. }
  147. });
  148. $("#hupbtn").click(function() {
  149. verto.hangup();
  150. cur_call = null;
  151. });
  152. $("#extbtn").click(function() {
  153. if($("#ext").val()){
  154. $("#ext").hide();
  155. $("#extbtn").hide();
  156. $("#cidname").show();
  157. $("#callbtn").show();
  158. $("#backbtn").show();
  159. $("#cidname").focus();
  160. $("#br").show();
  161. }
  162. });
  163. $("#backbtn").click(function() {
  164. $("#ext").show();
  165. $("#extbtn").show();
  166. $("#cidname").hide();
  167. $("#callbtn").hide();
  168. $("#hupbtn").hide();
  169. $("#chatwin").hide();
  170. $("#chatmsg").hide();
  171. $("#chatsend").hide();
  172. $("#backbtn").hide();
  173. cur_call = null;
  174. });
  175. function setupChat() {
  176. $("#chatwin").html("");
  177. $("#chatsend").click(function() {
  178. if (!cur_call && chatting_with) {
  179. return;
  180. }
  181. cur_call.message({to: chatting_with,
  182. body: $("#chatmsg").val(),
  183. from_msg_name: cur_call.params.caller_id_name,
  184. from_msg_number: cur_call.params.caller_id_number
  185. });
  186. $("#chatmsg").val("");
  187. });
  188. $("#chatmsg").keyup(function (event) {
  189. if (event.keyCode == 13 && !event.shiftKey) {
  190. $( "#chatsend" ).trigger( "click" );
  191. }
  192. });
  193. }
  194. function init() {
  195. cur_call = null;
  196. verto = new $.verto({
  197. login: $("#login").val() + "@" + $("#hostName").val(),
  198. passwd: $("#passwd").val(),
  199. socketUrl: $("#wsURL").val(),
  200. tag: "webcam",
  201. iceServers: true
  202. },callbacks);
  203. $("#ext").keyup(function (event) {
  204. if (event.keyCode == 13 && !event.shiftKey) {
  205. $( "#extbtn" ).trigger( "click" );
  206. }
  207. });
  208. $("#cidname").keyup(function (event) {
  209. if (event.keyCode == 13 && !event.shiftKey) {
  210. $( "#callbtn" ).trigger( "click" );
  211. }
  212. });
  213. $(document).keypress(function(event) {
  214. var key = String.fromCharCode(event.keyCode || event.charCode);
  215. var i = parseInt(key);
  216. if (key === "#" || key === "*" || key === "0" || (i > 0 && i <= 9)) {
  217. cur_call.dtmf(key);
  218. }
  219. });
  220. setupChat();
  221. }
  222. $(window).load(function() {
  223. cur_call = null;
  224. $("#conference").show();
  225. $("#backbtn").hide();
  226. $("#cidname").hide();
  227. $("#callbtn").hide();
  228. $("#hupbtn").hide();
  229. $("#chatwin").hide();
  230. $("#chatmsg").hide();
  231. $("#chatsend").hide();
  232. $("#webcam").hide();
  233. $("#video1").hide();
  234. init();
  235. });