index.html 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8" />
  5. <meta
  6. name="viewport"
  7. content="width=device-width, initial-scale=1, shrink-to-fit=no"
  8. />
  9. <!-- IMPORTANT SETUP -->
  10. <!-- Change the YOUR_API_KEY section of the config URL to match your API key -->
  11. <meta
  12. name="simplewebrtc-config-url"
  13. content="https://api.simplewebrtc.com/config/guest/YOUR_API_KEY"
  14. />
  15. <title>SimpleWebRTC Sample App</title>
  16. <style>
  17. body {
  18. margin: 0;
  19. padding: 0;
  20. -webkit-font-smoothing: antialiased;
  21. -moz-osx-font-smoothing: grayscale;
  22. min-height: 100%;
  23. font-family: -apple-system,
  24. BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu', 'Cantarell',
  25. 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;
  26. font-size: 16px;
  27. line-height: 1.5;
  28. color: #4d5659;
  29. text-rendering: optimizeSpeed;
  30. }
  31. code {
  32. font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New',
  33. monospace;
  34. }
  35. [hidden] {
  36. display: none;
  37. }
  38. a {
  39. background-color: transparent;
  40. text-decoration: none;
  41. }
  42. a:active,
  43. a:hover {
  44. outline: 0;
  45. }
  46. img {
  47. border: 0;
  48. }
  49. svg:not(:root) {
  50. overflow: hidden;
  51. }
  52. button,
  53. input {
  54. color: inherit;
  55. font: inherit;
  56. margin: 0;
  57. }
  58. button {
  59. overflow: visible;
  60. }
  61. button {
  62. text-transform: none;
  63. }
  64. button,
  65. html input[type='button'],
  66. input[type='reset'],
  67. input[type='submit'] {
  68. -webkit-appearance: button;
  69. cursor: pointer;
  70. }
  71. button[disabled],
  72. html input[disabled] {
  73. cursor: default;
  74. }
  75. button::-moz-focus-inner,
  76. input::-moz-focus-inner {
  77. border: 0;
  78. padding: 0;
  79. }
  80. input {
  81. line-height: normal;
  82. }
  83. *,
  84. *:after,
  85. *:before {
  86. box-sizing: border-box;
  87. }
  88. p {
  89. margin-top: 0;
  90. margin-bottom: 30px;
  91. }
  92. img,
  93. video {
  94. max-width: 100%;
  95. }
  96. html {
  97. box-sizing: border-box;
  98. }
  99. *,
  100. *:before,
  101. *:after {
  102. box-sizing: inherit;
  103. }
  104. * {
  105. margin: 0;
  106. padding: 0;
  107. }
  108. .create-room-form {
  109. text-align: center;
  110. }
  111. .create-room-form-input-wrapper {
  112. border: 1px #00b0e9 solid;
  113. padding: 10px;
  114. border-radius: 3px;
  115. }
  116. .create-room-form-input-wrapper:focus {
  117. border: 1px #f00 solid;
  118. }
  119. .domain {
  120. color: #b7c0c3;
  121. }
  122. .create-room-form-input {
  123. border: none;
  124. background: none;
  125. color: #00b0e9;
  126. }
  127. .create-room-form-input:focus {
  128. outline: none;
  129. }
  130. .create-room-form-button {
  131. margin-left: 5px;
  132. padding: 8px 10px !important;
  133. display: inline-block;
  134. }
  135. @media (max-width: 420px) {
  136. .create-room-form-input-wrapper {
  137. width: 100%;
  138. display: block;
  139. text-align: left;
  140. }
  141. .create-room-form-button {
  142. width: 100%;
  143. margin-top: 20px;
  144. display: block;
  145. margin-left: 0px;
  146. }
  147. .create-room-form-input {
  148. width: 75%;
  149. }
  150. }
  151. .container {
  152. margin: 60px auto;
  153. width: 85%;
  154. max-width: 800px;
  155. text-align: center;
  156. }
  157. </style>
  158. </head>
  159. <body>
  160. <noscript>
  161. You need to enable JavaScript to run this app.
  162. </noscript>
  163. <div id="root"></div>
  164. <template id="haircheck-header">
  165. <h2 style="text-align: center">Ready to join a video chat?</h2>
  166. </template>
  167. <template id="empty-peer-grid">
  168. <h2 style="text-align: center; color: rgba(68, 68, 68, 0.25)">
  169. There isn't anyone here (yet!)
  170. </h2>
  171. </template>
  172. <template id="empty-roster">
  173. <div></div>
  174. </template>
  175. <template id="homepage">
  176. <div class="container">
  177. <form class="create-room-form" method="GET" action="/">
  178. <span class="create-room-form-input-wrapper"
  179. ><span class="domain">localhost/</span
  180. ><input
  181. type="text"
  182. name="room"
  183. placeholder="choose a room name"
  184. class="create-room-form-input"/></span
  185. ><button
  186. class="create-room-form-button button button-default button-undefined"
  187. type="submit"
  188. >
  189. Start a chat
  190. </button>
  191. </form>
  192. </div>
  193. </template>
  194. <script type="text/javascript">
  195. const params = new URLSearchParams(window.location.search);
  196. SimpleWebRTC.run({
  197. roomName: params.get('room'),
  198. root: document.getElementById('root'),
  199. gridPlaceholder: () => SimpleWebRTC.loadTemplate('empty-peer-grid'),
  200. haircheckHeaderPlaceholder: () =>
  201. SimpleWebRTC.loadTemplate('haircheck-header'),
  202. emptyRosterPlaceholder: () => SimpleWebRTC.loadTemplate('empty-roster'),
  203. homepagePlaceholder: () => SimpleWebRTC.loadTemplate('homepage')
  204. });
  205. </script>
  206. </body>
  207. </html>