mirror of
				https://github.com/beatriceo/polyglot.git
				synced 2025-10-26 03:02:12 +00:00 
			
		
		
		
	Merge branch 'master' into cross
This commit is contained in:
		
							
								
								
									
										28
									
								
								.babelrc
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								.babelrc
									
									
									
									
									
								
							| @@ -1,18 +1,26 @@ | |||||||
| { | { | ||||||
|   "presets": [ |   "presets": [ | ||||||
|     ["env", { |     [ | ||||||
|       "modules": false, |       "env", | ||||||
|       "targets": { |       { | ||||||
|         "browsers": "> 1%", |         "modules": false, | ||||||
|         "uglify": true |         "targets": { | ||||||
|       }, |           "browsers": "> 1%", | ||||||
|       "useBuiltIns": true |           "uglify": true | ||||||
|     }] |         }, | ||||||
|  |         "useBuiltIns": true | ||||||
|  |       } | ||||||
|  |     ] | ||||||
|   ], |   ], | ||||||
|  |  | ||||||
|   "plugins": [ |   "plugins": [ | ||||||
|     "syntax-dynamic-import", |     "syntax-dynamic-import", | ||||||
|     "transform-object-rest-spread", |     "transform-object-rest-spread", | ||||||
|     ["transform-class-properties", { "spec": true }] |     "transform-runtime", | ||||||
|  |     [ | ||||||
|  |       "transform-class-properties", | ||||||
|  |       { | ||||||
|  |         "spec": true | ||||||
|  |       } | ||||||
|  |     ] | ||||||
|   ] |   ] | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								LICENSE
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								LICENSE
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | MIT License | ||||||
|  |  | ||||||
|  | Copyright (c) 2018 Beatrice Olivera | ||||||
|  |  | ||||||
|  | Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  | of this software and associated documentation files (the "Software"), to deal | ||||||
|  | in the Software without restriction, including without limitation the rights | ||||||
|  | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  | copies of the Software, and to permit persons to whom the Software is | ||||||
|  | furnished to do so, subject to the following conditions: | ||||||
|  |  | ||||||
|  | The above copyright notice and this permission notice shall be included in all | ||||||
|  | copies or substantial portions of the Software. | ||||||
|  |  | ||||||
|  | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  | SOFTWARE. | ||||||
| @@ -1 +1,8 @@ | |||||||
| Rails app generated with [lewagon/rails-templates](https://github.com/lewagon/rails-templates), created by the [Le Wagon coding bootcamp](https://www.lewagon.com) team. | # polyglot | ||||||
|  | A video call application made with Ruby on Rails and node.js. | ||||||
|  |  | ||||||
|  | Video calling is made possible with [WebRTC](https://webrtc.org/). | ||||||
|  |  | ||||||
|  | Signaling is done via ActionCable in Rails, a module that handles WebSockets. This section of the project was adapted from `@jeanpaulsio`'s project which can be found [here](https://github.com/jeanpaulsio/action-cable-signaling-server). | ||||||
|  |  | ||||||
|  | This Rails app was generated with [lewagon/rails-templates](https://github.com/lewagon/rails-templates), created by the [Le Wagon coding bootcamp](https://www.lewagon.com) team. | ||||||
|   | |||||||
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 1.6 MiB After Width: | Height: | Size: 153 KiB | 
| @@ -12,19 +12,23 @@ | |||||||
|  |  | ||||||
|     font-size: 2em; |     font-size: 2em; | ||||||
|     font-weight: bold; |     font-weight: bold; | ||||||
|  |     a:hover { | ||||||
|  |       color: $primary; | ||||||
|  |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|   .right-align { |   .right-align { | ||||||
|     height: 100%; |     height: 100%; | ||||||
|     width: 16em; |     width: 16em; | ||||||
|     margin-right: 5em; |     margin-right: 4em; | ||||||
|     display: flex; |     display: flex; | ||||||
|     align-items: center; |     align-items: center; | ||||||
|     justify-content: space-between; |     justify-content: space-between; | ||||||
|  |  | ||||||
|     .links { |     .links { | ||||||
|       display: flex; |       display: flex; | ||||||
|       height: inherit; |       height: inherit; | ||||||
|  |  | ||||||
|       div { |       div { | ||||||
|         height: inherit; |         height: inherit; | ||||||
|         display: flex; |         display: flex; | ||||||
| @@ -32,19 +36,26 @@ | |||||||
|         border-bottom: 5px solid transparent; |         border-bottom: 5px solid transparent; | ||||||
|  |  | ||||||
|         &:first-child { |         &:first-child { | ||||||
|           margin-right: 1em; |           margin-right: 2.5em; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         &.active { |         &.active { | ||||||
|           border-bottom: 5px solid $primary; |           border-bottom: 5px solid $primary; | ||||||
|           color: white; |           color: white; | ||||||
|  |  | ||||||
|            a { |  | ||||||
|             color: white; |  | ||||||
|            } |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         &:hover { | ||||||
|  |           color: white; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         &.active, &:hover { | ||||||
|  |           a { | ||||||
|  |             color: white; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |  | ||||||
|         a { |         a { | ||||||
|           color: #C4C4C4; |           color: $text-inactive; | ||||||
|           text-decoration: none; |           text-decoration: none; | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
| @@ -53,7 +64,28 @@ | |||||||
|  |  | ||||||
|   .profile { |   .profile { | ||||||
|     img { |     img { | ||||||
|       width: 3.25em; |       width: 3em; | ||||||
|  |       padding: 0.2em; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .burger-menu { | ||||||
|  |     margin-right: 20px; | ||||||
|  |     color: $primary; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .polyglot-dropdown { | ||||||
|  |     background-color: $navbar-background; | ||||||
|  |  | ||||||
|  |     li { | ||||||
|  |       a { | ||||||
|  |         color: $text-inactive; | ||||||
|  |  | ||||||
|  |         &:hover { | ||||||
|  |           color: white; | ||||||
|  |           background-color: $background; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ $gray-base:       $gray; | |||||||
| $brand-primary:   $primary; | $brand-primary:   $primary; | ||||||
| $brand-success:   $green; | $brand-success:   $green; | ||||||
| $brand-info:      $yellow; | $brand-info:      $yellow; | ||||||
| $brand-danger:    $red; | $brand-danger:    $warn; | ||||||
| $brand-warning:   $orange; | $brand-warning:   $orange; | ||||||
| $brand-secondary: $secondary; | $brand-secondary: $secondary; | ||||||
|  |  | ||||||
| @@ -52,3 +52,4 @@ $border-radius-small: 2px; | |||||||
| } | } | ||||||
|  |  | ||||||
| // Override other variables below! | // Override other variables below! | ||||||
|  | $input-border-focus: $primary; | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ $orange: #E67E22; | |||||||
| $green: #32B796; | $green: #32B796; | ||||||
| $gray: #000000; | $gray: #000000; | ||||||
| $light-gray: #F4F4F4; | $light-gray: #F4F4F4; | ||||||
|  | $warn: #3d63cc; | ||||||
|  |  | ||||||
| $primary: #F55E4F; | $primary: #F55E4F; | ||||||
| $secondary: #5ED17E; | $secondary: #5ED17E; | ||||||
| @@ -15,4 +16,5 @@ $background: #33333D; | |||||||
| $card-background: #464650; | $card-background: #464650; | ||||||
| $navbar-background: #1F1F29; | $navbar-background: #1F1F29; | ||||||
| $text-darker: #CDCDCD; | $text-darker: #CDCDCD; | ||||||
|  | $text-inactive: #C4C4C4; | ||||||
| $icon: #EDECEC; | $icon: #EDECEC; | ||||||
|   | |||||||
| @@ -1,9 +1,9 @@ | |||||||
| // Import Google fonts | // Import Google fonts | ||||||
| @import url("https://fonts.googleapis.com/css?family=Open+Sans:400,300,700|Raleway:400,100,300,700,500"); | @import url("https://fonts.googleapis.com/css?family=Assistant:400,700|Hind:400,700"); | ||||||
|  |  | ||||||
| // Define fonts for body and headers | // Define fonts for body and headers | ||||||
| $body-font: "Open Sans", "Helvetica", "sans-serif"; | $body-font: "Hind", "Helvetica", "sans-serif"; | ||||||
| $headers-font: "Raleway", "Helvetica", "sans-serif"; | $headers-font: "Assistant", "Helvetica", "sans-serif"; | ||||||
|  |  | ||||||
| // To use a font file (.woff) uncomment following lines | // To use a font file (.woff) uncomment following lines | ||||||
| // @font-face { | // @font-face { | ||||||
|   | |||||||
| @@ -18,13 +18,13 @@ | |||||||
|     url('https://unsplash.com/photos/jay5BqVyf5A'); |     url('https://unsplash.com/photos/jay5BqVyf5A'); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   .login-content { |   .login-content { | ||||||
|     position: relative; |     position: relative; | ||||||
|     top: -10vh; |     // top: -10vh; | ||||||
|     padding: 50px; |     padding: 50px; | ||||||
|     background-color: white; |     background-color: white; | ||||||
|     width: 25vw; |     width: 25vw; | ||||||
|  |     min-width: 300px; | ||||||
|     border-radius: 3px; |     border-radius: 3px; | ||||||
|     box-shadow: 1px 1px 10px rgba(0,0,0, 0.21); |     box-shadow: 1px 1px 10px rgba(0,0,0, 0.21); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,6 +12,7 @@ a:hover { | |||||||
| } | } | ||||||
|  |  | ||||||
| .card { | .card { | ||||||
|  |   min-width: 360px; | ||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
|   background: $card-background; |   background: $card-background; | ||||||
| @@ -73,8 +74,17 @@ a:hover { | |||||||
| } | } | ||||||
|  |  | ||||||
| .video-content { | .video-content { | ||||||
|   height: 485px; |   // height: 485px; | ||||||
|   background-color: black; |  | ||||||
|  |   padding-left: 0.2vw; | ||||||
|  |   display: flex; | ||||||
|  |   justify-content: center; | ||||||
|  |   .flex-video { | ||||||
|  |     height: 100%; | ||||||
|  |     width: 100%; | ||||||
|  |     flex: 1 1 auto; | ||||||
|  |   } | ||||||
|  |   // background-color: black; | ||||||
| } | } | ||||||
|  |  | ||||||
| .half { | .half { | ||||||
| @@ -91,6 +101,8 @@ a:hover { | |||||||
|   align-items: center; |   align-items: center; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // Modal | ||||||
|  |  | ||||||
| .modal-header { | .modal-header { | ||||||
|   border-bottom: 0px; |   border-bottom: 0px; | ||||||
|   i { |   i { | ||||||
| @@ -100,6 +112,7 @@ a:hover { | |||||||
|  |  | ||||||
| .modal-color { | .modal-color { | ||||||
|   background-color: $card-background; |   background-color: $card-background; | ||||||
|  |   min-width: 296px; | ||||||
| } | } | ||||||
|  |  | ||||||
| .vertical-alignment-helper { | .vertical-alignment-helper { | ||||||
| @@ -133,17 +146,28 @@ a:hover { | |||||||
|   align-items: center; |   align-items: center; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .modal-flex { | ||||||
|  |   display: flex; | ||||||
|  |   flex-wrap: wrap; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @media only screen and (max-width: 1100px) { | ||||||
|  |     .modal-picture { | ||||||
|  |       width: 50px; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // Contact | ||||||
|  |  | ||||||
| .contact { | .contact { | ||||||
|   color: white; |   color: white; | ||||||
| } | } | ||||||
|  |  | ||||||
| .contacts { | .contacts { | ||||||
|   height: 570px; |   display: flex; | ||||||
|   overflow: scroll; |   flex-direction: column; | ||||||
|  |   justify-content: center; | ||||||
| } | } | ||||||
|  |  | ||||||
| .close { | .close { | ||||||
| @@ -159,12 +183,10 @@ a:hover { | |||||||
|   filter: alpha(opacity=20); |   filter: alpha(opacity=20); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .contacts-list{ | ||||||
|  |   height: 90vh; | ||||||
|  |   overflow: scroll; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,4 +1,3 @@ | |||||||
| // Specific CSS for your home-page |  | ||||||
| video { | video { | ||||||
|   transform: rotateY(180deg); |   transform: rotateY(180deg); | ||||||
|   -webkit-transform:rotateY(180deg); /* Safari and Chrome */ |   -webkit-transform:rotateY(180deg); /* Safari and Chrome */ | ||||||
|   | |||||||
| @@ -1,3 +1,4 @@ | |||||||
| // Import page-specific CSS files here. | // Import page-specific CSS files here. | ||||||
| @import "home"; | @import "home"; | ||||||
| @import "contacts" | @import "contacts"; | ||||||
|  | @import "settings"; | ||||||
|   | |||||||
							
								
								
									
										125
									
								
								app/assets/stylesheets/pages/_settings.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										125
									
								
								app/assets/stylesheets/pages/_settings.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,125 @@ | |||||||
|  | .card-form { | ||||||
|  |   padding: 20px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .card-form-no-hover { | ||||||
|  |   &:hover { | ||||||
|  |     box-shadow: 1px 1px 15px 1px rgba(0, 0, 0, 0.2); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .input-dropdown { | ||||||
|  |   width: 196px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .switch { | ||||||
|  |   position: relative; | ||||||
|  |   display: inline-block; | ||||||
|  |   width: 60px; | ||||||
|  |   height: 34px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .switch input {display:none;} | ||||||
|  |  | ||||||
|  | .slider { | ||||||
|  |   position: absolute; | ||||||
|  |   cursor: pointer; | ||||||
|  |   top: 0; | ||||||
|  |   left: 0; | ||||||
|  |   right: 0; | ||||||
|  |   bottom: 0; | ||||||
|  |   background-color: #ccc; | ||||||
|  |   -webkit-transition: .4s; | ||||||
|  |   transition: .4s; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .slider:before { | ||||||
|  |   position: absolute; | ||||||
|  |   content: ""; | ||||||
|  |   height: 26px; | ||||||
|  |   width: 26px; | ||||||
|  |   left: 4px; | ||||||
|  |   bottom: 4px; | ||||||
|  |   background-color: white; | ||||||
|  |   -webkit-transition: .4s; | ||||||
|  |   transition: .4s; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input:checked + .slider { | ||||||
|  |   background-color: $primary; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input:focus + .slider { | ||||||
|  |   box-shadow: 0 0 1px $primary; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input:checked + .slider:before { | ||||||
|  |   -webkit-transform: translateX(26px); | ||||||
|  |   -ms-transform: translateX(26px); | ||||||
|  |   transform: translateX(26px); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* Rounded sliders */ | ||||||
|  | .slider.round { | ||||||
|  |   border-radius: 34px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .slider.round:before { | ||||||
|  |   border-radius: 50%; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .input-field-text-black { | ||||||
|  |   color: black; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .slider.rounded { | ||||||
|  |   border-radius: 3px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .slider.rounded:before { | ||||||
|  |   border-radius: 3px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | .settings { | ||||||
|  |   color: white; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .no-padding { | ||||||
|  |   padding: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .no-margin { | ||||||
|  |   margin: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .font-weight-normal { | ||||||
|  |   font-weight: normal; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .padding-right { | ||||||
|  |   padding-right: 10px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .margin-right { | ||||||
|  |   margin-right: 10px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .flex-inline { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: row; | ||||||
|  |   align-items: center; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .space-between { | ||||||
|  |   justify-content: space-between; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .center-screen { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  |   justify-content: center; | ||||||
|  |   align-items: center; | ||||||
|  |   text-align: center; | ||||||
|  |   min-height: 80vh; | ||||||
|  | } | ||||||
| @@ -3,7 +3,8 @@ | |||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   height: calc(100vh - 4.5em); // 4.5em is height of navbar |   padding-top: 30px; | ||||||
|  |   // height: calc(100vh - 4.5em); // 4.5em is height of navbar | ||||||
|  |  | ||||||
|   form { |   form { | ||||||
|     flex-grow: 1; |     flex-grow: 1; | ||||||
| @@ -22,10 +23,18 @@ | |||||||
|  |  | ||||||
|     img { |     img { | ||||||
|       max-width: 50vw; |       max-width: 50vw; | ||||||
|  |       padding-top: 30px; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .small-profile-pic { | ||||||
|  |   img { | ||||||
|  |     width: 223px; | ||||||
|  |     margin-bottom: 20px; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
| .profile-form { | .profile-form { | ||||||
|   display: grid; |   display: grid; | ||||||
|   grid-template-columns: 1fr 1fr; |   grid-template-columns: 1fr 1fr; | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ | |||||||
|   display:flex; |   display:flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|  |   text-align: center; | ||||||
|  |  | ||||||
|   h2 { |   h2 { | ||||||
|     font-size: 1.5em; |     font-size: 1.5em; | ||||||
| @@ -21,33 +22,43 @@ | |||||||
|         margin-right: .5em; |         margin-right: .5em; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     .profile-pic { |  | ||||||
|       display: flex; |  | ||||||
|       align-items: center; |  | ||||||
|       margin-right: 3em; |  | ||||||
|       img { |  | ||||||
|         width: 10em; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     .profile-text { |  | ||||||
|       display: flex; |  | ||||||
|       flex-direction: column; |  | ||||||
|       justify-content: center; |  | ||||||
|       color: #f2321f; |  | ||||||
|       h1 { |  | ||||||
|         margin: 0 0 .5em 0 ; |  | ||||||
|       } |  | ||||||
|       h2 { |  | ||||||
|         margin: 0; |  | ||||||
|       } |  | ||||||
|       .italics { |  | ||||||
|         font-style: italic; |  | ||||||
|         color: white; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .profile-text { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  |   justify-content: center; | ||||||
|  |   color: $primary; | ||||||
|  |   h1 { | ||||||
|  |     margin: 0 0 .5em 0 ; | ||||||
|   } |   } | ||||||
|  |   h2 { | ||||||
|  |     margin: 0; | ||||||
|  |   } | ||||||
|  |   .italics { | ||||||
|  |     font-style: italic; | ||||||
|  |     color: white; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .vcenter { | ||||||
|  |   display: inline-block; | ||||||
|  |   vertical-align: middle; | ||||||
|  |   float: none; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .vertical-padding { | ||||||
|  |   padding-top: 5px; | ||||||
|  |   padding-bottom: 5px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .vertical-margin { | ||||||
|  |   margin-top: 5px; | ||||||
|  |   margin-bottom: 5px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .img-profile { | ||||||
|  |   width: 200px; | ||||||
|  |   height: 200px; | ||||||
|  | } | ||||||
|   | |||||||
| @@ -6,4 +6,8 @@ class ApplicationController < ActionController::Base | |||||||
|   def after_sign_in_path_for(resource) |   def after_sign_in_path_for(resource) | ||||||
|     contacts_path |     contacts_path | ||||||
|   end |   end | ||||||
|  |  | ||||||
|  |   def default_url_options | ||||||
|  |     { host: ENV["HOST"] || "localhost:3000" } | ||||||
|  |   end | ||||||
| end | end | ||||||
|   | |||||||
| @@ -1,6 +1,5 @@ | |||||||
| class ConnectionsController < ApplicationController | class ConnectionsController < ApplicationController | ||||||
|   def new |   def new | ||||||
|  |  | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   def create |   def create | ||||||
| @@ -10,9 +9,17 @@ class ConnectionsController < ApplicationController | |||||||
|     @connection.contact = contact_user |     @connection.contact = contact_user | ||||||
|  |  | ||||||
|     if @connection.save |     if @connection.save | ||||||
|         redirect_to contacts_path |       contact_message = nil | ||||||
|  |       if contact_user.first_name.nil? || contact_user.last_name.nil? | ||||||
|  |         contact_message = "#{contact_user.email}" | ||||||
|  |       else | ||||||
|  |         contact_message = "#{contact_user.first_name} #{contact_user.last_name}" | ||||||
|  |       end | ||||||
|  |       flash[:notice] = "Added #{contact_message} to contacts" | ||||||
|  |       redirect_to contacts_path | ||||||
|     else |     else | ||||||
|  |       flash[:alert] = "Invalid email address!" | ||||||
|  |       render 'new' | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,8 +13,6 @@ class PagesController < ApplicationController | |||||||
|   end |   end | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   def cable_testing |   def cable_testing | ||||||
|     chatroom = 'chat_room_' + params[:chat_room_id] |     chatroom = 'chat_room_' + params[:chat_room_id] | ||||||
|     puts params |     puts params | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								app/helpers/meta_tags_helper.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								app/helpers/meta_tags_helper.rb
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | module MetaTagsHelper | ||||||
|  |   def meta_title | ||||||
|  |     content_for?(:meta_title) ? content_for(:meta_title) : DEFAULT_META["meta_title"] | ||||||
|  |   end | ||||||
|  |  | ||||||
|  |   def meta_description | ||||||
|  |     content_for?(:meta_description) ? content_for(:meta_description) : DEFAULT_META["meta_description"] | ||||||
|  |   end | ||||||
|  |  | ||||||
|  |   def meta_image | ||||||
|  |     meta_image = (content_for?(:meta_image) ? content_for(:meta_image) : DEFAULT_META["meta_image"]) | ||||||
|  |     # little twist to make it work equally with an asset or a url | ||||||
|  |     meta_image.starts_with?("http") ? meta_image : image_url(meta_image) | ||||||
|  |   end | ||||||
|  | end | ||||||
| @@ -1,11 +1,15 @@ | |||||||
|  |  | ||||||
| const triggerModalEvent = () => { | const triggerModalEvent = () => { | ||||||
|   const btn = document.getElementById("modalTrigger"); |  | ||||||
|   const modal = document.getElementById("myModal"); |  | ||||||
|  |  | ||||||
|   btn.addEventListener('click', function(event) { |   const buttons = document.querySelectorAll(".modalTrigger"); | ||||||
|     $('#myModal').modal('show'); |  | ||||||
|   }); |   buttons.forEach(btn => { | ||||||
|  |     if (btn) { | ||||||
|  |       btn.addEventListener('click', function(event) { | ||||||
|  |         const btnId = btn.getAttribute('data-user-id') | ||||||
|  |         $("#myModal"+`${btnId}`).modal('show'); | ||||||
|  |       }); | ||||||
|  |     } | ||||||
|  |   }) | ||||||
| } | } | ||||||
|  |  | ||||||
| export { triggerModalEvent } | export { triggerModalEvent } | ||||||
|   | |||||||
| @@ -4,6 +4,35 @@ import { triggerModalEvent } from "../components/modal.js"; | |||||||
|  |  | ||||||
| triggerModalEvent(); | triggerModalEvent(); | ||||||
|  |  | ||||||
| // import { profilePageAnimation } from '../users/lesson'; | const settingsPage = document.getElementById('settings-page'); | ||||||
|  | const contactsPage = document.getElementById('contacts-page'); | ||||||
|  |  | ||||||
|  | const getSiblings = (element) => { | ||||||
|  |   const siblings = []; | ||||||
|  |   let sibling = element.parentNode.firstChild; | ||||||
|  |   const skipMe = element; | ||||||
|  |   for ( ; sibling; sibling = sibling.nextSibling ) | ||||||
|  |     if ( sibling.nodeType == 1 && sibling != element ) | ||||||
|  |       siblings.push( sibling ); | ||||||
|  |   return siblings; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | const removeActiveClass = (element) => { | ||||||
|  |   const siblings = getSiblings(element); | ||||||
|  |   siblings.forEach(sibling => { | ||||||
|  |     sibling.classList.remove('active'); | ||||||
|  |   }); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | if (settingsPage) { | ||||||
|  |   const settings = document.getElementById('settings') | ||||||
|  |   settings.classList.add('active'); | ||||||
|  |   removeActiveClass(settings); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | if (contactsPage) { | ||||||
|  |   const contacts = document.getElementById('contacts') | ||||||
|  |   contacts.classList.add('active'); | ||||||
|  |   removeActiveClass(contacts); | ||||||
|  | } | ||||||
|  |  | ||||||
| // profilePageAnimation(); |  | ||||||
|   | |||||||
| @@ -23,13 +23,13 @@ App['chatroom' + chatroomId] = App.cable.subscriptions.create({ | |||||||
| }) | }) | ||||||
|  |  | ||||||
| // Testing ActionCable | // Testing ActionCable | ||||||
| const testBtn = document.getElementById('test-btn') | // const testBtn = document.getElementById('test-btn') | ||||||
| testBtn.addEventListener('click', event => { | // testBtn.addEventListener('click', event => { | ||||||
|   fetch(`/chat_rooms/${chatroomId}/cable_testing` , { | //   fetch(`/chat_rooms/${chatroomId}/cable_testing` , { | ||||||
|     method: 'POST', | //     method: 'POST', | ||||||
|     body: JSON.stringify({}) | //     body: JSON.stringify({}) | ||||||
|   }) | //   }) | ||||||
| }) | // }) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								app/javascript/packs/local_video.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								app/javascript/packs/local_video.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | const contactsVideo = document.getElementById("contacts-video") | ||||||
|  |  | ||||||
|  | try { | ||||||
|  |   const contactsStream = navigator.mediaDevices.getUserMedia({ | ||||||
|  |     audio: false, | ||||||
|  |     video: true | ||||||
|  |   }).then(stream => { | ||||||
|  |     contactsVideo.srcObject = stream; | ||||||
|  |     contactsVideo.muted = true; | ||||||
|  |   }) | ||||||
|  | } catch(e) { | ||||||
|  |   console.error(e); | ||||||
|  |   contactsVideo.innerHTML = "Unable to getUserMedia()"; | ||||||
|  | } | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| import ActionCable from 'actioncable' | import ActionCable from 'actioncable' | ||||||
|  |  | ||||||
| // create App object with key cable == new cosumer | // create App object with key cable == new consumer | ||||||
| (function() { | (function() { | ||||||
|   window.App || (window.App = {}); |   window.App || (window.App = {}); | ||||||
|  |  | ||||||
| @@ -12,7 +12,6 @@ import ActionCable from 'actioncable' | |||||||
| const userId = parseInt(document.getElementById("my-user-id").dataset["userId"]) | const userId = parseInt(document.getElementById("my-user-id").dataset["userId"]) | ||||||
| let chatRoomId = null | let chatRoomId = null | ||||||
|  |  | ||||||
|  |  | ||||||
| App.cable.subscriptions.create({ | App.cable.subscriptions.create({ | ||||||
|   channel: 'NotificationsChannel' |   channel: 'NotificationsChannel' | ||||||
| }, { | }, { | ||||||
| @@ -24,19 +23,13 @@ App.cable.subscriptions.create({ | |||||||
|     // console.log(userId) |     // console.log(userId) | ||||||
|     console.log("received broadcast") |     console.log("received broadcast") | ||||||
|     // console.log(data.body) |     // console.log(data.body) | ||||||
|     if (data.head === 302 && data.body["caller"] === userId && data.path ) { |     if (data.head === 302 && data.body["caller"] === userId && data.path) { | ||||||
|       window.location.pathname = data.path |       window.location.pathname = data.path | ||||||
|     } else if (data["message"]["user_id"] === userId) { |     } else if (data["message"]["user_id"] === userId) { // Some error appears here but it is not fatal | ||||||
|       console.log("TRIGGER MODAL") |       console.log("TRIGGER MODAL") | ||||||
|       const acceptButton = document.getElementById('accept-button') |       const acceptButton = document.getElementById('accept-button') | ||||||
|       acceptButton.style.display = "block" |       acceptButton.style.display = "block" | ||||||
|       // const receiveCall = document.getElementById('receive-call') |  | ||||||
|       // receiveCall.dataset.toggle = 'modal' |  | ||||||
|       // receiveCall.dataset.target ='#calleeModal' |  | ||||||
|       // console.log(receiveCall) |  | ||||||
|  |  | ||||||
|       // const calleeModal = document.getElementById('calleeModal') |  | ||||||
|       // calleeModal.modal("show") |  | ||||||
|       chatRoomId = data["message"]["chat_room_id"] |       chatRoomId = data["message"]["chat_room_id"] | ||||||
|       console.log(`user with id: ${userId} needs to subscribe to chatroom ${[chatRoomId]}`) |       console.log(`user with id: ${userId} needs to subscribe to chatroom ${[chatRoomId]}`) | ||||||
|     } else { |     } else { | ||||||
| @@ -47,10 +40,9 @@ App.cable.subscriptions.create({ | |||||||
|   } |   } | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | // Receive information from index.html.erb | ||||||
| const acceptButton = document.getElementById('accept-button') | const acceptButton = document.getElementById('accept-button') | ||||||
|  |  | ||||||
| acceptButton.addEventListener('click', event => { | acceptButton.addEventListener('click', event => { | ||||||
|   // event.preventDefault() |  | ||||||
|   document.getElementById('chat-room-id').value = chatRoomId |   document.getElementById('chat-room-id').value = chatRoomId | ||||||
| }) | }) | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								app/javascript/packs/settings_video.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								app/javascript/packs/settings_video.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | const contactsVideo = document.getElementById("settings-video") | ||||||
|  |  | ||||||
|  | try { | ||||||
|  |   const contactsStream = navigator.mediaDevices.getUserMedia({ | ||||||
|  |     audio: false, | ||||||
|  |     video: true | ||||||
|  |   }).then(stream => { | ||||||
|  |     contactsVideo.srcObject = stream; | ||||||
|  |     contactsVideo.muted = true; | ||||||
|  |   }) | ||||||
|  | } catch(e) { | ||||||
|  |   console.error(e); | ||||||
|  |   contactsVideo.innerHTML = "Unable to getUserMedia()"; | ||||||
|  | } | ||||||
| @@ -1,7 +1,5 @@ | |||||||
| // Broadcast Types
 | // Broadcast Types
 | ||||||
| 
 | 
 | ||||||
| class Signaling {} |  | ||||||
| 
 |  | ||||||
| const JOIN_ROOM = "JOIN_ROOM"; | const JOIN_ROOM = "JOIN_ROOM"; | ||||||
| const EXCHANGE = "EXCHANGE"; | const EXCHANGE = "EXCHANGE"; | ||||||
| const REMOVE_USER = "REMOVE_USER"; | const REMOVE_USER = "REMOVE_USER"; | ||||||
| @@ -16,12 +14,9 @@ let pcPeers = {}; // peer connection | |||||||
| let localstream; | let localstream; | ||||||
| 
 | 
 | ||||||
| window.onload = () => { | window.onload = () => { | ||||||
|   // if (document.getElementById("current-user")) {
 |   currentUser = document.getElementById("current-user").innerHTML; | ||||||
|     currentUser = document.getElementById("current-user").innerHTML; |   localVideo = document.getElementById("local-video"); | ||||||
|     console.log(currentUser) |   remoteVideoContainer = document.getElementById("remote-video-container"); | ||||||
|     localVideo = document.getElementById("local-video"); |  | ||||||
|     remoteVideoContainer = document.getElementById("remote-video-container"); |  | ||||||
|   // }
 |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // Ice Credentials
 | // Ice Credentials
 | ||||||
| @@ -37,45 +32,14 @@ document.onreadystatechange = async () => { | |||||||
|       }) |       }) | ||||||
| 
 | 
 | ||||||
|       localstream = stream; |       localstream = stream; | ||||||
|       // if (localVideo) {
 |       localVideo.srcObject = stream | ||||||
|         localVideo.srcObject = stream |       localVideo.muted = true | ||||||
|         localVideo.muted = true |  | ||||||
|       // }
 |  | ||||||
|     } catch (e) { console.error(e); } |     } catch (e) { console.error(e); } | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // find chatroom
 |  | ||||||
| // const handleJoinSession = async () => {
 |  | ||||||
| //   App.session = await App.cable.subscriptions.create("VideoSessionChannel", {
 |  | ||||||
| //     connected: () => {
 |  | ||||||
| //       broadcastData({
 |  | ||||||
| //         type: JOIN_ROOM,
 |  | ||||||
| //         from: currentUser
 |  | ||||||
| //       });
 |  | ||||||
| //     },
 |  | ||||||
| //     received: data => {
 |  | ||||||
| //       console.log("received", data);
 |  | ||||||
| //       if (data.from === currentUser) return;
 |  | ||||||
| //       switch (data.type) {
 |  | ||||||
| //         case JOIN_ROOM:
 |  | ||||||
| //           return joinRoom(data);
 |  | ||||||
| //         case EXCHANGE:
 |  | ||||||
| //           if (data.to !== currentUser) return;
 |  | ||||||
| //           return exchange(data);
 |  | ||||||
| //         case REMOVE_USER:
 |  | ||||||
| //           return removeUser(data);
 |  | ||||||
| //         default:
 |  | ||||||
| //           return;
 |  | ||||||
| //       }
 |  | ||||||
| //     }
 |  | ||||||
| //   });
 |  | ||||||
| // };
 |  | ||||||
| 
 | 
 | ||||||
| // if (document.getElementById('chatroom-hook')) {
 | const chatroomId = document.getElementById('chatroom-hook').dataset["chatroomId"] | ||||||
|   const chatroomId = document.getElementById('chatroom-hook').dataset["chatroomId"] |  | ||||||
| 
 |  | ||||||
| // }
 |  | ||||||
| 
 | 
 | ||||||
| const handleJoinSession = async () => { | const handleJoinSession = async () => { | ||||||
|   App['chatroom' + chatroomId] = await App.cable.subscriptions.create({ |   App['chatroom' + chatroomId] = await App.cable.subscriptions.create({ | ||||||
| @@ -83,7 +47,6 @@ const handleJoinSession = async () => { | |||||||
|     room: chatroomId |     room: chatroomId | ||||||
|   }, { |   }, { | ||||||
|     connected: () => { |     connected: () => { | ||||||
|       console.log(chatroomId) |  | ||||||
|       broadcastData({ |       broadcastData({ | ||||||
|         type: JOIN_ROOM, |         type: JOIN_ROOM, | ||||||
|         from: currentUser, |         from: currentUser, | ||||||
| @@ -91,7 +54,6 @@ const handleJoinSession = async () => { | |||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|     received: data => { |     received: data => { | ||||||
|       console.log(data) |  | ||||||
|       if (data.from === currentUser) return; |       if (data.from === currentUser) return; | ||||||
|       switch (data.type) { |       switch (data.type) { | ||||||
|         case JOIN_ROOM: |         case JOIN_ROOM: | ||||||
| @@ -136,9 +98,6 @@ const removeUser = data => { | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const broadcastData = data => { | const broadcastData = data => { | ||||||
|   if (data.type === EXCHANGE) { |  | ||||||
|     console.log("yayyy") |  | ||||||
|   } |  | ||||||
|   fetch("chat_room_sessions", { |   fetch("chat_room_sessions", { | ||||||
|     method: "POST", |     method: "POST", | ||||||
|     body: JSON.stringify(data), |     body: JSON.stringify(data), | ||||||
| @@ -220,7 +179,7 @@ const exchange = data => { | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (data.sdp) { |   if (data.sdp) { | ||||||
|     sdp = JSON.parse(data.sdp); |     const sdp = JSON.parse(data.sdp); | ||||||
|     pc |     pc | ||||||
|       .setRemoteDescription(new RTCSessionDescription(sdp)) |       .setRemoteDescription(new RTCSessionDescription(sdp)) | ||||||
|       .then(() => { |       .then(() => { | ||||||
| @@ -242,3 +201,15 @@ const exchange = data => { | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const logError = error => console.warn("Whoops! Error:", error); | const logError = error => console.warn("Whoops! Error:", error); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | const joinButton = document.getElementById("join-btn") | ||||||
|  | joinButton.addEventListener('click', event => { | ||||||
|  |   handleJoinSession() | ||||||
|  | }) | ||||||
|  | 
 | ||||||
|  | // WARNING: COMPLETELY HACKISH SOLUTION --> MUST INTRODUCE SOME SORT OF DELAY!
 | ||||||
|  | setTimeout(function() { | ||||||
|  |   joinButton.click() | ||||||
|  | }, 5000); | ||||||
|  | 
 | ||||||
| @@ -1,27 +1,19 @@ | |||||||
| <button onclick="handleJoinSession()" data-room="<%= @chat_room.id %>">Join Room</button> | <div id="join-btn" data-room="<%= @chat_room.id %>"></div> | ||||||
| <!-- <div id="join-session" data-room="<%= @chat_room.id %>"> --> |  | ||||||
| <!-- <h1 style="color: white;">This is chatroom #<%= @chat_room.id %></h1> --> |  | ||||||
| <div id="chatroom-hook" data-chatroom-id='<%= @chat_room.id %>'></div> | <div id="chatroom-hook" data-chatroom-id='<%= @chat_room.id %>'></div> | ||||||
|  |  | ||||||
| <!-- <button id="test-btn">Test Connection</button> --> |  | ||||||
| <div class="call-container"> | <div class="call-container"> | ||||||
|   <div id="remote-video-container"> |   <div id="remote-video-container"> | ||||||
|     <div id="video_overlays"> |     <div id="video_overlays"> | ||||||
|       <video id="local-video" autoplay></video> |       <video id="local-video" autoplay muted></video> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
| <div> | <div><span id="current-user" class="text-color" style="display:none"><%= current_user.id %></span></div> | ||||||
|   <span id="current-user" class="text-color" style="display:none"><%= current_user.id %></span> |  | ||||||
| </div> |  | ||||||
|  |  | ||||||
| <!-- <script> |  | ||||||
|   const joinSession = document.getElementById("join-session") |  | ||||||
|   joinSession.addEventListener('load', event => { |  | ||||||
|     handleJoinSession() |  | ||||||
|   }) |  | ||||||
| </script> --> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <%= javascript_pack_tag 'chatrooms' %> | <%= javascript_pack_tag 'chatrooms' %> | ||||||
|  | <%= javascript_pack_tag 'webrtc' %> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,8 +1,23 @@ | |||||||
| <div class="align-center"> | <% params["action"] = "Add contact" %> | ||||||
|   <h2>Add a new contact:</h2> |  | ||||||
|   <%= form_for User.new, url: connections_path do |f| %> |  | ||||||
|     <%= f.label :email, class: "email_label_color" %>: |  | ||||||
|     <%= f.text_field :email %> |  | ||||||
|  |  | ||||||
|     <%= f.submit %> | <div class="center-screen"> | ||||||
|   <% end %> |   <div class="align-center"> | ||||||
|  |     <div class="container"> | ||||||
|  |       <div class="row"> | ||||||
|  |         <div class="col-xs-offset-2 col-xs-8 col-xs-offset-2"> | ||||||
|  |           <h2>Enter an email address:</h2> | ||||||
|  |         </div> | ||||||
|  |         <%= simple_form_for User.new, url: connections_path, class: "input-group" do |f| %> | ||||||
|  |           <div class="col-xs-offset-2 col-xs-8 col-xs-offset-2 "> | ||||||
|  |             <div class="flex-inline"> | ||||||
|  |               <%= f.input_field :email, class: "form-control margin-right" %> | ||||||
|  |               <div class="input-group-append"> | ||||||
|  |               <%= f.button :submit, value: "Add Contact" , class: "btn btn-primary" %> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         <% end %> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </div> | ||||||
|   | |||||||
| @@ -11,11 +11,19 @@ | |||||||
|         <%= f.input :password, |         <%= f.input :password, | ||||||
|                     required: false, |                     required: false, | ||||||
|                     input_html: { autocomplete: "current-password" } %> |                     input_html: { autocomplete: "current-password" } %> | ||||||
|         <%= f.input :remember_me, as: :boolean if devise_mapping.rememberable? %> |         <div class="flex-inline space-between"> | ||||||
|  |           <%= f.label :remember_me %> | ||||||
|  |           <label class="switch"> | ||||||
|  |             <%= f.input_field :enable_transcript, as: :boolean if devise_mapping.rememberable? %> | ||||||
|  |             <span class="slider rounded"></span> | ||||||
|  |           </label> | ||||||
|  |         </div> | ||||||
|  |  | ||||||
|  |         <%#= f.input :remember_me, as: :boolean if devise_mapping.rememberable? %> | ||||||
|       </div> |       </div> | ||||||
|  |  | ||||||
|       <div class="form-actions"> |       <div class="form-actions"> | ||||||
|         <%= f.button :submit, "Log in", class: "login btn btn-primary" %> |         <%= f.button :submit, "Log in", class: "login btn btn-primary vertical-margin" %> | ||||||
|       </div> |       </div> | ||||||
|     <% end %> |     <% end %> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,11 +3,11 @@ | |||||||
| <% end -%> | <% end -%> | ||||||
|  |  | ||||||
| <%- if devise_mapping.registerable? && controller_name != 'registrations' %> | <%- if devise_mapping.registerable? && controller_name != 'registrations' %> | ||||||
|   <%#= link_to "Sign up", new_registration_path(resource_name) %><!-- <br /> --> |   <%= link_to "Sign up", new_registration_path(resource_name) %><!-- <br /> --> | ||||||
| <% end -%> | <% end -%> | ||||||
|  |  | ||||||
| <%- if devise_mapping.recoverable? && controller_name != 'passwords' && controller_name != 'registrations' %> | <%- if devise_mapping.recoverable? && controller_name != 'passwords' && controller_name != 'registrations' %> | ||||||
|   <%= link_to "Forgot your password?", new_password_path(resource_name) %><br /> |   <%#= link_to "Forgot your password?", new_password_path(resource_name) %><br /> | ||||||
| <% end -%> | <% end -%> | ||||||
|  |  | ||||||
| <%- if devise_mapping.confirmable? && controller_name != 'confirmations' %> | <%- if devise_mapping.confirmable? && controller_name != 'confirmations' %> | ||||||
|   | |||||||
| @@ -3,12 +3,18 @@ | |||||||
|   <head> |   <head> | ||||||
|     <meta charset="UTF-8"> |     <meta charset="UTF-8"> | ||||||
|     <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> |     <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> | ||||||
|         <%= favicon_link_tag 'favicon.ico' %> <!-- Need a favicon to change picture in title bar --> |     <%= favicon_link_tag 'favicon.ico' %> <!-- Need a favicon to change picture in title bar --> | ||||||
|     <title>Polyglot</title> |     <title>Polyglot - Live Translation</title> | ||||||
|     <%= csrf_meta_tags %> |     <%= csrf_meta_tags %> | ||||||
|     <%= action_cable_meta_tag %> |     <%= action_cable_meta_tag %> | ||||||
|     <%= stylesheet_link_tag 'application', media: 'all' %> |     <%= stylesheet_link_tag 'application', media: 'all' %> | ||||||
|     <%#= stylesheet_pack_tag 'application', media: 'all' %> <!-- Uncomment if you import CSS in app/javascript/packs/application.js --> |     <%#= stylesheet_pack_tag 'application', media: 'all' %> <!-- Uncomment if you import CSS in app/javascript/packs/application.js --> | ||||||
|  |     <meta property="og:title" content="<%= meta_title %>" /> | ||||||
|  |     <meta property="og:type" content="website" /> | ||||||
|  |     <meta property="og:url" content="<%= request.original_url %>" /> | ||||||
|  |     <meta property="og:image" content="<%= meta_image %>" /> | ||||||
|  |     <meta property="og:description" content="<%= meta_description %>" /> | ||||||
|  |     <meta property="og:site_name" content="<%= meta_title %>" /> | ||||||
|   </head> |   </head> | ||||||
|   <body> |   <body> | ||||||
|     <%= render 'shared/navbar' unless params["action"] == "home" || params["action"] == "new" || params["action"] == "call" %> |     <%= render 'shared/navbar' unless params["action"] == "home" || params["action"] == "new" || params["action"] == "call" %> | ||||||
| @@ -16,6 +22,5 @@ | |||||||
|     <%= yield %> |     <%= yield %> | ||||||
|     <%= javascript_include_tag 'application' %> |     <%= javascript_include_tag 'application' %> | ||||||
|     <%= javascript_pack_tag 'application' %> |     <%= javascript_pack_tag 'application' %> | ||||||
|  |  | ||||||
|   </body> |   </body> | ||||||
| </html> | </html> | ||||||
|   | |||||||
| @@ -1,9 +1,3 @@ | |||||||
| <% |  | ||||||
| def hello_world |  | ||||||
|   puts "Hello World" |  | ||||||
| end |  | ||||||
| %> |  | ||||||
|  |  | ||||||
| <div class="card"> | <div class="card"> | ||||||
|   <div class="info"> |   <div class="info"> | ||||||
|     <% if contact.photo.url.nil? %> |     <% if contact.photo.url.nil? %> | ||||||
| @@ -12,17 +6,17 @@ end | |||||||
|       <%= cl_image_tag contact.photo, class: "profile avatar dropdown-toggle img-circle", width:65%> |       <%= cl_image_tag contact.photo, class: "profile avatar dropdown-toggle img-circle", width:65%> | ||||||
|     <% end %> |     <% end %> | ||||||
|     <div class="text text-color"> |     <div class="text text-color"> | ||||||
|       <% if contact.nil? || contact.nil? %> <!-- REPLACE WITH FIRST NAME AND LAST NAME --> |       <% if contact.first_name.nil? || contact.last_name.nil? %> | ||||||
|         <p><%= contact.email %></p> |         <p><%= contact.email %></p> | ||||||
|       <% else %> |       <% else %> | ||||||
|         <p><%= contact.email %></p> |         <p><%= contact.first_name %> <%= contact.last_name %></p> | ||||||
|         <!-- <p><%#= contact.first_name %> <%#= contact.last_name %></p> --> |  | ||||||
|       <% end %> |       <% end %> | ||||||
|       <p class="darker">Last call: <%= Time.now %></p> |       <p class="darker">Last call: <%= Time.now %></p> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
|   <div class="call" data-user-id="<%= contact.id %>"> |   <div class="call" data-user-id="<%= contact.id %>"> | ||||||
|     <%= link_to establish_call_path(contact.id), remote: true, id: "modalTrigger" do  %> |     <!-- Calls establish_call in pages_controller --> | ||||||
|  |     <%= link_to establish_call_path(contact.id), remote: true, class: "modalTrigger", data: {'user-id': contact.id } do  %> | ||||||
|       <i class="fas fa-phone"></i> |       <i class="fas fa-phone"></i> | ||||||
|     <% end %> |     <% end %> | ||||||
|   </div> |   </div> | ||||||
| @@ -32,30 +26,30 @@ end | |||||||
|  |  | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <!-- Modal --> | <!-- Modal --> | ||||||
| <div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true"> | <div class="modal fade" id="myModal<%= contact.id %>" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true"> | ||||||
|   <div class="vertical-alignment-helper"> |   <div class="vertical-alignment-helper"> | ||||||
|     <div class="modal-dialog vertical-align-center"> |     <div class="modal-dialog vertical-align-center"> | ||||||
|       <div class="modal-content modal-color"> |       <div class="modal-content modal-color"> | ||||||
|         <div class="modal-header"> |         <div class="modal-header"> | ||||||
|           <%= link_to "#", class:"pull-right", 'data-dismiss':"modal", 'data-target':"#myModal" do  %> |           <%= link_to "#", class:"pull-right", 'data-dismiss':"modal", 'data-target':"#myModal#{contact.id}" do  %> | ||||||
|             <i class="fas fa-times-circle"></i> |             <i class="fas fa-times-circle"></i> | ||||||
|           <% end %> |           <% end %> | ||||||
|           <div class="container"> |           <div class="container"> | ||||||
|             <div class="modal-container"> |             <div class="modal-container modal-flex"> | ||||||
|               <img src="https://kitt.lewagon.com/placeholder/users/ssaunier" alt="" class="profile img-circle" width=150> |               <% if contact.photo.url.nil? %> | ||||||
|  |                 <img src="https://upload.wikimedia.org/wikipedia/commons/8/89/Portrait_Placeholder.png" class="avatar profile dropdown-toggle img-circle modal-picture" width=150> | ||||||
|  |               <% else %> | ||||||
|  |                 <%= cl_image_tag contact.photo, class: "profile avatar dropdown-toggle img-circle modal-picture", width:150%> | ||||||
|  |               <% end %> | ||||||
|               <div class="modal-text"> |               <div class="modal-text"> | ||||||
|                 <h4 class="modal-title" id="myModalLabel">Calling</h4> |                 <h4 class="modal-title" id="myModalLabel">Calling</h4> | ||||||
|                 <h4> |                 <h4> | ||||||
|                   <strong> |                   <strong> | ||||||
|                     <!-- REPLACE WITH FIRST NAME AND LAST NAME --> |                     <% if contact.first_name.nil? || contact.last_name.nil? %> | ||||||
|                     <% if contact.nil? || contact.nil? %> |  | ||||||
|                       <p><%= contact.email %></p> |                       <p><%= contact.email %></p> | ||||||
|                     <% else %> |                     <% else %> | ||||||
|                       <p><%= contact.email %></p> |                       <p><%= contact.first_name %> <%= contact.last_name %></p> | ||||||
|                       <!-- <p><%#= contact.first_name %> <%#= contact.last_name %></p> --> |  | ||||||
|                     <% end %> |                     <% end %> | ||||||
|                   </strong> |                   </strong> | ||||||
|                 </h4> |                 </h4> | ||||||
|   | |||||||
| @@ -1,28 +1,37 @@ | |||||||
|  | <div id="contacts-page"></div> | ||||||
|  |  | ||||||
|  | <!-- CONTACTS PAGE --> | ||||||
| <div class="container"> | <div class="container"> | ||||||
|   <div class="contacts-container text-color"> |   <div class="contacts-container text-color"> | ||||||
|     <div class="contacts half"> |     <div class="row"> | ||||||
|       <div class="contacts-header"> |       <div class="col-xs-12 col-md-6"> | ||||||
|         <h2>Contacts</h2> |         <div class="contacts"> | ||||||
|  |           <div class="contacts-header"> | ||||||
|         <%= link_to new_connection_path do %> |             <h2>Contacts</h2> | ||||||
|           <i class="fas fa-plus-square"></i> |             <%= link_to add_contact_path do %> | ||||||
|         <% end %> |               <i class="fas fa-plus-square"></i> | ||||||
|  |             <% end %> | ||||||
|  |           </div> | ||||||
|  |           <div class="contacts-list"> | ||||||
|  |             <% current_user.contacts.each do |contact| %> | ||||||
|  |               <%= render "pages/contact", contact: contact %> | ||||||
|  |             <% end %> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|       </div> |       </div> | ||||||
|       <% current_user.contacts.each do |contact| %> |  | ||||||
|         <%= render "pages/contact", contact: contact %> |  | ||||||
|       <% end %> |  | ||||||
|  |  | ||||||
|  |       <div class="col-xs-12 col-md-6 hidden-xs hidden-sm"> | ||||||
|  |         <div class="video-feed"> | ||||||
|     </div> |           <div class="video-content"> | ||||||
|     <div class="video-feed half"> |             <video id="contacts-video" class="flex-video" autoplay=""></video> | ||||||
|       <div class="video-content"> |           </div> | ||||||
|         <!-- <video id="contacts-video" autoplay=""></video> --> |         </div> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | <!-- INFORMATION TO BE PASSED TO NOTIFICATIONS.JS --> | ||||||
| <div id="my-user-id" data-user-id="<%= current_user.id %>"></div> | <div id="my-user-id" data-user-id="<%= current_user.id %>"></div> | ||||||
|  |  | ||||||
| <form action="/accept_call" method="post"> | <form action="/accept_call" method="post"> | ||||||
| @@ -31,5 +40,6 @@ | |||||||
| </form> | </form> | ||||||
|  |  | ||||||
| <%= javascript_pack_tag 'notifications' %> | <%= javascript_pack_tag 'notifications' %> | ||||||
|  | <%= javascript_pack_tag 'local_video' %> | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,3 +8,5 @@ | |||||||
|  |  | ||||||
|   <%= p.button :submit, class: "btn btn-primary" %> |   <%= p.button :submit, class: "btn btn-primary" %> | ||||||
| <% end %> | <% end %> | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,32 +1,45 @@ | |||||||
| <div class="polyglot-navbar"> | <div class="polyglot-navbar"> | ||||||
|   <div class="logo"> |   <div class="logo"><%= link_to "Polyglot", contacts_path %></div> | ||||||
|       Polyglot |  | ||||||
|   </div> |  | ||||||
|  |  | ||||||
|   <div class="right-align"> |   <div class="right-align hidden-xs hidden-sm"> | ||||||
|     <div class="links"> |     <div class="links"> | ||||||
|       <div class="active"><%= link_to "Dashboard", contacts_path %></div> |       <div id="contacts"><%= link_to "Contacts", contacts_path %></div> | ||||||
|       <div><%= link_to "Settings", setting_path %></div> |       <div id="settings"><%= link_to "Settings", setting_path %></div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="profile"> |     <div class="profile"> | ||||||
|     <% if current_user.nil? %> |       <% if current_user.nil? %> | ||||||
|       <%= link_to "Login", new_user_session_path  %> |         <%= link_to "Login", new_user_session_path  %> | ||||||
|     <% else %> |       <% else %> | ||||||
|       <div class="dropdown"> |         <div class="dropdown"> | ||||||
|         <div data-toggle="dropdown"> |           <div data-toggle="dropdown"> | ||||||
|           <% if current_user.photo.url.nil? %> |             <% if current_user.photo.url.nil? %> | ||||||
|             <img src="https://upload.wikimedia.org/wikipedia/commons/8/89/Portrait_Placeholder.png" class="avatar dropdown-toggle img-circle"> |               <img src="https://upload.wikimedia.org/wikipedia/commons/8/89/Portrait_Placeholder.png" class="avatar dropdown-toggle img-circle"> | ||||||
|           <% else %> |             <% else %> | ||||||
|             <%= cl_image_tag current_user.photo, class: "avatar dropdown-toggle img-circle"%> |               <%= cl_image_tag current_user.photo, class: "avatar dropdown-toggle img-circle"%> | ||||||
|           <% end %> |             <% end %> | ||||||
|  |           </div> | ||||||
|  |           <ul class="dropdown-menu dropdown-menu-right polyglot-dropdown"> | ||||||
|  |             <li><%= link_to "Profile", user_path(current_user) %></li> | ||||||
|  |             <li><%= link_to "Logout", destroy_user_session_path %></li> | ||||||
|  |           </ul> | ||||||
|         </div> |         </div> | ||||||
|         <ul class="dropdown-menu dropdown-menu-right"> |       <% end %> | ||||||
|           <!-- <li><a href="#">Profile</a></li> --> |     </div> | ||||||
|           <li><%= link_to "Profile", user_path(current_user) %></li> |   </div> | ||||||
|           <li><%= link_to "Logout", destroy_user_session_path %></li> |  | ||||||
|         </ul> |   <div class="burger-menu hidden-md hidden-lg"> | ||||||
|       </div> |     <div class="dropdown"> | ||||||
|     <% end %> |       <i class="fa fa-bars dropdown-toggle" data-toggle="dropdown"></i> | ||||||
|  |       <ul class="dropdown-menu dropdown-menu-right polyglot-dropdown"> | ||||||
|  |         <li><%= link_to "Contacts", contacts_path %></li> | ||||||
|  |         <li><%= link_to "Settings", setting_path %></li> | ||||||
|  |           <% if current_user.nil? %> | ||||||
|  |             <li><%= link_to "Login", new_user_session_path  %></li> | ||||||
|  |           <% else %> | ||||||
|  |             <li><%= link_to "Profile", user_path(current_user) %></li> | ||||||
|  |             <li><%= link_to "Logout", destroy_user_session_path %></li> | ||||||
|  |           <% end %> | ||||||
|  |       </ul> | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| </div> | </div> | ||||||
|   | |||||||
| @@ -7,25 +7,24 @@ | |||||||
|         <%= t.input :last_name %> |         <%= t.input :last_name %> | ||||||
|         <%= t.input :password %> |         <%= t.input :password %> | ||||||
|         <%= t.input :photo %> |         <%= t.input :photo %> | ||||||
|  |         <div class="small-profile-pic hidden-md hidden-lg"> | ||||||
|  |           <% if @user.photo.url.nil? %> | ||||||
|  |             <%= image_tag "https://upload.wikimedia.org/wikipedia/commons/8/89/Portrait_Placeholder.png"%> | ||||||
|  |           <% else %> | ||||||
|  |             <%= cl_image_tag current_user.photo%> | ||||||
|  |           <% end %> | ||||||
|  |         </div> | ||||||
|         <%= t.submit :Save, class: "btn btn-primary save-btn form-control" %> |         <%= t.submit :Save, class: "btn btn-primary save-btn form-control" %> | ||||||
|         <p></p> |         <p></p> | ||||||
|         <%= link_to "View my profile", user_path(@user), class: "btn btn-primary save-btn form-control" %> |         <%= link_to "View my profile", user_path(@user), class: "btn btn-primary save-btn form-control" %> | ||||||
|       </div> |       </div> | ||||||
|  |       <div class="profile-pic hidden-xs hidden-sm"> | ||||||
|  |  | ||||||
|       <div class="profile-pic"> |  | ||||||
|         <% if @user.photo.url.nil? %> |         <% if @user.photo.url.nil? %> | ||||||
|           <%= image_tag "https://upload.wikimedia.org/wikipedia/commons/8/89/Portrait_Placeholder.png"%> |           <%= image_tag "https://upload.wikimedia.org/wikipedia/commons/8/89/Portrait_Placeholder.png"%> | ||||||
|         <% else %> |         <% else %> | ||||||
|           <%= cl_image_tag current_user.photo%> |           <%= cl_image_tag current_user.photo%> | ||||||
|         <% end %> |         <% end %> | ||||||
|  |  | ||||||
|         <%#= t.input_field :photo, onchange: 'this.form.submit();' %> |  | ||||||
|         <%#= t.input_field :photo, as: :hidden %> |  | ||||||
|  |  | ||||||
|       </div> |       </div> | ||||||
|  |  | ||||||
|     </div> |     </div> | ||||||
|   <% end %> |   <% end %> | ||||||
| </div> | </div> | ||||||
|   | |||||||
| @@ -1,158 +1,101 @@ | |||||||
| <div class="profile-container"> | <div id="settings-page"></div> | ||||||
|   <%= simple_form_for(@user) do |t| %> |  | ||||||
|     <div class="profile-form"> |  | ||||||
|       <div> |  | ||||||
|         <div class="lign"> |  | ||||||
|  |  | ||||||
|        <div class="card"><%= t.input :language, collection: | <% languages = [ | ||||||
| [ |   "Afrikaans (South Africa)", "Amharic (Ethiopia)", "Armenian (Armenia)", | ||||||
| "Afrikaans (South Africa)", |   "Azerbaijani (Azerbaijan)", "Indonesian (Indonesia)", "Malay (Malaysia)", | ||||||
| "Amharic (Ethiopia)", |   "Bengali (Bangladesh)", "Bengali (India)", "Catalan (Spain)", | ||||||
| "Armenian (Armenia)", |   "Czech (Czech Republic)", "Danish (Denmark)", "German (Germany)", | ||||||
| "Azerbaijani (Azerbaijan)", |   "English (Australia)", "English (Canada)", "English (Ghana)", | ||||||
| "Indonesian (Indonesia)", |   "English (United Kingdom)", "English (India)", "English (Ireland)", | ||||||
| "Malay (Malaysia)", |   "English (Kenya)", "English (New Zealand)", "English (Nigeria)", | ||||||
| "Bengali (Bangladesh)", |   "English (Philippines)", "English (South Africa)", "English (Tanzania)", | ||||||
| "Bengali (India)", |   "English (United States)", "Spanish (Argentina)", "Spanish (Bolivia)", | ||||||
| "Catalan (Spain)", |   "Spanish (Chile)", "Spanish (Colombia)", "Spanish (Costa Rica)", | ||||||
| "Czech (Czech Republic)", |   "Spanish (Ecuador)", "Spanish (El Salvador)", "Spanish (Spain)", | ||||||
| "Danish (Denmark)", |   "Spanish (United States)", "Spanish (Guatemala)", "Spanish (Honduras)", | ||||||
| "German (Germany)", |   "Spanish (Mexico)", "Spanish (Nicaragua)", "Spanish (Panama)", | ||||||
| "English (Australia)", |   "Spanish (Paraguay)", "Spanish (Peru)", "Spanish (Puerto Rico)", | ||||||
| "English (Canada)", |   "Spanish (Dominican Republic)", "Spanish (Uruguay)", "Spanish (Venezuela)", | ||||||
| "English (Ghana)", |   "Basque (Spain)", "Filipino (Philippines)", "French (Canada)", | ||||||
| "English (United Kingdom)", |   "French (France)", "Galician (Spain)", "Georgian (Georgia)", | ||||||
| "English (India)", |   "Gujarati (India)", "Croatian (Croatia)", "Zulu (South Africa)", | ||||||
| "English (Ireland)", |   "Icelandic (Iceland)", "Italian (Italy)", "Javanese (Indonesia)", | ||||||
| "English (Kenya)", |   "Kannada (India)", "Khmer (Cambodia)", "Lao (Laos)", | ||||||
| "English (New Zealand)", |   "Latvian (Latvia)", "Lithuanian (Lithuania)", "Hungarian (Hungary)", | ||||||
| "English (Nigeria)", |   "Malayalam (India)", "Marathi (India)", "Dutch (Netherlands)", | ||||||
| "English (Philippines)", |   "Nepali (Nepal)", "Norwegian Bokmål (Norway)", "Polish (Poland)", | ||||||
| "English (South Africa)", |   "Portuguese (Brazil)", "Portuguese (Portugal)", "Romanian (Romania)", | ||||||
| "English (Tanzania)", |   "Sinhala (Sri Lanka)", "Slovak (Slovakia)", "Slovenian (Slovenia)", | ||||||
| "English (United States)", |   "Sundanese (Indonesia)", "Swahili (Tanzania)", "Swahili (Kenya)", | ||||||
| "Spanish (Argentina)", |   "Finnish (Finland)", "Swedish (Sweden)", "Tamil (India)", | ||||||
| "Spanish (Bolivia)", |   "Tamil (Singapore)", "Tamil (Sri Lanka)", "Tamil (Malaysia)", | ||||||
| "Spanish (Chile)", |   "Telugu (India)", "Vietnamese (Vietnam)", "Turkish (Turkey)", | ||||||
| "Spanish (Colombia)", |   "Urdu (Pakistan)", "Urdu (India)", "Greek (Greece)", | ||||||
| "Spanish (Costa Rica)", |   "Bulgarian (Bulgaria)", "Russian (Russia)", "Serbian (Serbia)", | ||||||
| "Spanish (Ecuador)", |   "Ukrainian (Ukraine)", "Hebrew (Israel)", "Arabic (Israel)", | ||||||
| "Spanish (El Salvador)", |   "Arabic (Jordan)", "Arabic (United Arab Emirates)", "Arabic (Bahrain)", | ||||||
| "Spanish (Spain)", |   "Arabic (Algeria)", "Arabic (Saudi Arabia)", "Arabic (Iraq)", | ||||||
| "Spanish (United States)", |   "Arabic (Kuwait)", "Arabic (Morocco)", "Arabic (Tunisia)", | ||||||
| "Spanish (Guatemala)", |   "Arabic (Oman)", "Arabic (Qatar)", "Arabic (Lebanon)", | ||||||
| "Spanish (Honduras)", |   "Arabic (Egypt)", "Persian (Iran)", "Hindi (India)", | ||||||
| "Spanish (Mexico)", |   "Thai (Thailand)", "Korean (South Korea)", "Chinese, Mandarin (Traditional, Taiwan)", | ||||||
| "Spanish (Nicaragua)", |   "Chinese, Cantonese (Traditional, Hong Kong)", "Japanese (Japan)", | ||||||
| "Spanish (Panama)", |   "Chinese, Mandarin (Simplified, Hong Kong)", | ||||||
| "Spanish (Paraguay)", |   "Chinese, Mandarin (Simplified, China)" ]%> | ||||||
| "Spanish (Peru)", |  | ||||||
| "Spanish (Puerto Rico)", |  | ||||||
| "Spanish (Dominican Republic)", |  | ||||||
| "Spanish (Uruguay)", |  | ||||||
| "Spanish (Venezuela)", |  | ||||||
| "Basque (Spain)", |  | ||||||
| "Filipino (Philippines)", |  | ||||||
| "French (Canada)", |  | ||||||
| "French (France)", |  | ||||||
| "Galician (Spain)", |  | ||||||
| "Georgian (Georgia)", |  | ||||||
| "Gujarati (India)", |  | ||||||
| "Croatian (Croatia)", |  | ||||||
| "Zulu (South Africa)", |  | ||||||
| "Icelandic (Iceland)", |  | ||||||
| "Italian (Italy)", |  | ||||||
| "Javanese (Indonesia)", |  | ||||||
| "Kannada (India)", |  | ||||||
| "Khmer (Cambodia)", |  | ||||||
| "Lao (Laos)", |  | ||||||
| "Latvian (Latvia)", |  | ||||||
| "Lithuanian (Lithuania)", |  | ||||||
| "Hungarian (Hungary)", |  | ||||||
| "Malayalam (India)", |  | ||||||
| "Marathi (India)", |  | ||||||
| "Dutch (Netherlands)", |  | ||||||
| "Nepali (Nepal)", |  | ||||||
| "Norwegian Bokmål (Norway)", |  | ||||||
| "Polish (Poland)", |  | ||||||
| "Portuguese (Brazil)", |  | ||||||
| "Portuguese (Portugal)", |  | ||||||
| "Romanian (Romania)", |  | ||||||
| "Sinhala (Sri Lanka)", |  | ||||||
| "Slovak (Slovakia)", |  | ||||||
| "Slovenian (Slovenia)", |  | ||||||
| "Sundanese (Indonesia)", |  | ||||||
| "Swahili (Tanzania)", |  | ||||||
| "Swahili (Kenya)", |  | ||||||
| "Finnish (Finland)", |  | ||||||
| "Swedish (Sweden)", |  | ||||||
| "Tamil (India)", |  | ||||||
| "Tamil (Singapore)", |  | ||||||
| "Tamil (Sri Lanka)", |  | ||||||
| "Tamil (Malaysia)", |  | ||||||
| "Telugu (India)", |  | ||||||
| "Vietnamese (Vietnam)", |  | ||||||
| "Turkish (Turkey)", |  | ||||||
| "Urdu (Pakistan)", |  | ||||||
| "Urdu (India)", |  | ||||||
| "Greek (Greece)", |  | ||||||
| "Bulgarian (Bulgaria)", |  | ||||||
| "Russian (Russia)", |  | ||||||
| "Serbian (Serbia)", |  | ||||||
| "Ukrainian (Ukraine)", |  | ||||||
| "Hebrew (Israel)", |  | ||||||
| "Arabic (Israel)", |  | ||||||
| "Arabic (Jordan)", |  | ||||||
| "Arabic (United Arab Emirates)", |  | ||||||
| "Arabic (Bahrain)", |  | ||||||
| "Arabic (Algeria)", |  | ||||||
| "Arabic (Saudi Arabia)", |  | ||||||
| "Arabic (Iraq)", |  | ||||||
| "Arabic (Kuwait)", |  | ||||||
| "Arabic (Morocco)", |  | ||||||
| "Arabic (Tunisia)", |  | ||||||
| "Arabic (Oman)", |  | ||||||
| "Arabic (Qatar)", |  | ||||||
| "Arabic (Lebanon)", |  | ||||||
| "Arabic (Egypt)", |  | ||||||
| "Persian (Iran)", |  | ||||||
| "Hindi (India)", |  | ||||||
| "Thai (Thailand)", |  | ||||||
| "Korean (South Korea)", |  | ||||||
| "Chinese, Mandarin (Traditional, Taiwan)", |  | ||||||
| "Chinese, Cantonese (Traditional, Hong Kong)", |  | ||||||
| "Japanese (Japan)", |  | ||||||
| "Chinese, Mandarin (Simplified, Hong Kong)", |  | ||||||
| "Chinese, Mandarin (Simplified, China)"] %> |  | ||||||
|  |  | ||||||
|  | <% fonts = [ | ||||||
|  |     "Arial", | ||||||
|  |     "Times New Roman", | ||||||
|  |     "Calibri" | ||||||
|  |   ] %> | ||||||
|  |  | ||||||
|  | <div class="container"> | ||||||
|  |   <div class="contacts-container"> | ||||||
|  |     <div class="row"> | ||||||
|  |       <div class="col-xs-12 col-md-6"> | ||||||
|  |         <div class="settings"> | ||||||
|  |           <h2>Settings</h2> | ||||||
|  |           <div> | ||||||
|  |             <%= simple_form_for(@user) do |t| %> | ||||||
|  |               <div> | ||||||
|  |                 <div class="card card-form card-form-no-hover"> | ||||||
|  |                   <%= t.label :language, class:'padding-right no-margin font-weight-normal' %> | ||||||
|  |                   <%= t.input_field :language, collection: languages.sort, class:'input-field-text-black input-dropdown form-control' %> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="card card-form card-form-no-hover"> | ||||||
|  |                   <%= t.label :caption_font, class:'padding-right no-margin font-weight-normal' %> | ||||||
|  |                   <%= t.input_field :caption_font, collection: fonts.sort, class:'input-field-text-black input-dropdown form-control' %> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="card card-form card-form-no-hover"> | ||||||
|  |                   <%= t.label :caption_font_size, class:'padding-right no-margin font-weight-normal' %> | ||||||
|  |                   <%= t.input_field :caption_font_size, class:'input-field-text-black input-dropdown form-control' %> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="card card-form card-form-no-hover"> | ||||||
|  |                   <%= t.label :enable_transcript, class:'padding-right no-margin font-weight-normal' %> | ||||||
|  |                   <label class="switch"> | ||||||
|  |                     <%= t.input_field :enable_transcript, class:'input-field-text-black' %> | ||||||
|  |                     <span class="slider round"></span> | ||||||
|  |                   </label> | ||||||
|  |                 </div> | ||||||
|  |  | ||||||
|  |                 <%= link_to "Save", contacts_path, class: "btn btn-primary save-btn form-control" %> | ||||||
|  |                 <p></p> | ||||||
|  |               </div> | ||||||
|  |             <% end %> | ||||||
|  |           </div> | ||||||
|         </div> |         </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="col-xs-12 col-md-6 hidden-xs hidden-sm"> | ||||||
|  |         <div class="video-feed"> | ||||||
|  |           <div class="video-content"> | ||||||
|  |             <video id="settings-video" class="flex-video" autoplay=""></video> | ||||||
|  |           </div> | ||||||
|         </div> |         </div> | ||||||
|        <div class="card"><%= t.input :caption_font %></div> |  | ||||||
|        <div class="card"><%= t.input :caption_font_size %></div> |  | ||||||
|        <div class="card"><%= t.input :enable_transcript %></div> |  | ||||||
|  |  | ||||||
|         <%= link_to "Save", contacts_path, class: "btn btn-primary save-btn form-control" %> |  | ||||||
|         <p></p> |  | ||||||
|       </div> |       </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|       <div class="profile-pic"> |  | ||||||
|         <% if @user.photo.url.nil? %> |  | ||||||
|           <%= image_tag "https://upload.wikimedia.org/wikipedia/commons/8/89/Portrait_Placeholder.png"%> |  | ||||||
|         <% else %> |  | ||||||
|           <%= cl_image_tag current_user.photo%> |  | ||||||
|         <% end %> |  | ||||||
|  |  | ||||||
|         <%#= t.input_field :photo, onchange: 'this.form.submit();' %> |  | ||||||
|         <%#= t.input_field :photo, as: :hidden %> |  | ||||||
|  |  | ||||||
|       </div> |  | ||||||
|  |  | ||||||
|     </div> |     </div> | ||||||
|   <% end %> |   </div> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | <%= javascript_pack_tag 'settings_video' %> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,27 +1,28 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| <div class="user-container"> | <div class="user-container"> | ||||||
|   <div class="profile"> |   <div class="row"> | ||||||
|     <div class="profile-pic"> |     <div class="col-xs-12 col-md-3 vcenter"> | ||||||
|       <% if @user.photo.url.nil? %> |       <div class="profile-pic vertical-padding"> | ||||||
|         <%= image_tag "https://upload.wikimedia.org/wikipedia/commons/8/89/Portrait_Placeholder.png", class: "img-circle"%> |         <% if @user.photo.url.nil? %> | ||||||
|       <% else %> |           <%= image_tag "https://upload.wikimedia.org/wikipedia/commons/8/89/Portrait_Placeholder.png", class: "img-circle img-profile"%> | ||||||
|         <%= cl_image_tag @user.photo, class: "img-circle"%> |         <% else %> | ||||||
|       <% end %> |           <%= cl_image_tag @user.photo, class: "img-circle img-profile"%> | ||||||
|  |         <% end %> | ||||||
|  |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <div class="profile-text"> |     <div class="col-xs-12 col-md-4 vcenter"> | ||||||
|       <h1><%= @user.first_name %> <%= @user.last_name %></h1> |       <div class="profile-text vertical-padding"> | ||||||
|       <h2 class="italics" ><%= @user.email %></h2> |         <h1><%= @user.first_name %> <%= @user.last_name %></h1> | ||||||
|  |         <h2 class="italics" ><%= @user.email %></h2> | ||||||
|  |       </div> | ||||||
|     </div> |     </div> | ||||||
|  |     <div class="col-xs-12 col-md-4 vcenter"> | ||||||
|       <div class="flex-end"> |       <div class="flex-end vertical-padding"> | ||||||
|         <%= link_to "Edit Information", user_edit_path(@user), class: "btn btn-primary" %> |         <%= link_to "Edit Information", user_edit_path(@user), class: "btn btn-primary vertical-margin" %> | ||||||
|         <%= link_to "Delete Account", user_path(@user), class: "btn btn-danger", method: :delete, data: { |         <%= link_to "Delete Account", user_path(@user), class: "btn btn-danger vertical-margin", method: :delete, data: { | ||||||
|             confirm: "Are you sure?" |             confirm: "Are you sure?" | ||||||
|           } %> |           } %> | ||||||
|       </div> |       </div> | ||||||
|  |     </div> | ||||||
|   </div> |   </div> | ||||||
|  </div> | </div> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ Rails.application.configure do | |||||||
|   # config.assets.css_compressor = :sass |   # config.assets.css_compressor = :sass | ||||||
|  |  | ||||||
|   # Do not fallback to assets pipeline if a precompiled asset is missed. |   # Do not fallback to assets pipeline if a precompiled asset is missed. | ||||||
|   config.assets.compile = false |   config.assets.compile = true | ||||||
|  |  | ||||||
|   # `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb |   # `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								config/initializers/default_meta.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								config/initializers/default_meta.rb
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | DEFAULT_META = YAML.load_file(Rails.root.join("config/meta.yml")) | ||||||
							
								
								
									
										5
									
								
								config/meta.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								config/meta.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | meta_product_name: "Product Name" | ||||||
|  | meta_title: "Polyglot - Live translation" | ||||||
|  | meta_description: "Translate your call live" | ||||||
|  | meta_image: "phone.jpg"                       # should exist in `app/assets/images/` | ||||||
|  | twitter_account: "@EthanFraenkel"   # required for Twitter Cards | ||||||
| @@ -36,12 +36,11 @@ Rails.application.routes.draw do | |||||||
|   # For details on the DSL available within this file, see http://guides.rubyonrails.org/routing.html |   # For details on the DSL available within this file, see http://guides.rubyonrails.org/routing.html | ||||||
|   get '/home', to: 'pages#home' |   get '/home', to: 'pages#home' | ||||||
|  |  | ||||||
|  |  | ||||||
|   get '/users/:id', to: 'users#show', as: :user |   get '/users/:id', to: 'users#show', as: :user | ||||||
|   get '/users/:id/edit', to: 'users#edit', as: :user_edit |   get '/users/:id/edit', to: 'users#edit', as: :user_edit | ||||||
|   patch '/users/:id', to: 'users#update' |   patch '/users/:id', to: 'users#update' | ||||||
|   delete '/users/:id', to: 'users#destroy' |   delete '/users/:id', to: 'users#destroy' | ||||||
|  |  | ||||||
|   resources :connections, only: [:create, :new, :destroy] |   resources :connections, only: [:create, :destroy] | ||||||
|   #get '/add_contact', to: 'connections#create' |   get '/add_contact', to: 'connections#new', as: :add_contact | ||||||
| end | end | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ | |||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@rails/webpacker": "3.5", |     "@rails/webpacker": "3.5", | ||||||
|     "actioncable": "^5.2.1", |     "actioncable": "^5.2.1", | ||||||
|  |     "babel-plugin-transform-runtime": "^6.23.0", | ||||||
|     "bootstrap": "3", |     "bootstrap": "3", | ||||||
|     "jquery": "^3.3.1" |     "jquery": "^3.3.1" | ||||||
|   }, |   }, | ||||||
|   | |||||||
| @@ -1,67 +1,2 @@ | |||||||
| <!DOCTYPE html> | <h1>404 Error</h1> | ||||||
| <html> | <p>Ethan, fix this</p> | ||||||
| <head> |  | ||||||
|   <title>The page you were looking for doesn't exist (404)</title> |  | ||||||
|   <meta name="viewport" content="width=device-width,initial-scale=1"> |  | ||||||
|   <style> |  | ||||||
|   .rails-default-error-page { |  | ||||||
|     background-color: #EFEFEF; |  | ||||||
|     color: #2E2F30; |  | ||||||
|     text-align: center; |  | ||||||
|     font-family: arial, sans-serif; |  | ||||||
|     margin: 0; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page div.dialog { |  | ||||||
|     width: 95%; |  | ||||||
|     max-width: 33em; |  | ||||||
|     margin: 4em auto 0; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page div.dialog > div { |  | ||||||
|     border: 1px solid #CCC; |  | ||||||
|     border-right-color: #999; |  | ||||||
|     border-left-color: #999; |  | ||||||
|     border-bottom-color: #BBB; |  | ||||||
|     border-top: #B00100 solid 4px; |  | ||||||
|     border-top-left-radius: 9px; |  | ||||||
|     border-top-right-radius: 9px; |  | ||||||
|     background-color: white; |  | ||||||
|     padding: 7px 12% 0; |  | ||||||
|     box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page h1 { |  | ||||||
|     font-size: 100%; |  | ||||||
|     color: #730E15; |  | ||||||
|     line-height: 1.5em; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page div.dialog > p { |  | ||||||
|     margin: 0 0 1em; |  | ||||||
|     padding: 1em; |  | ||||||
|     background-color: #F7F7F7; |  | ||||||
|     border: 1px solid #CCC; |  | ||||||
|     border-right-color: #999; |  | ||||||
|     border-left-color: #999; |  | ||||||
|     border-bottom-color: #999; |  | ||||||
|     border-bottom-left-radius: 4px; |  | ||||||
|     border-bottom-right-radius: 4px; |  | ||||||
|     border-top-color: #DADADA; |  | ||||||
|     color: #666; |  | ||||||
|     box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |  | ||||||
|   } |  | ||||||
|   </style> |  | ||||||
| </head> |  | ||||||
|  |  | ||||||
| <body class="rails-default-error-page"> |  | ||||||
|   <!-- This file lives in public/404.html --> |  | ||||||
|   <div class="dialog"> |  | ||||||
|     <div> |  | ||||||
|       <h1>The page you were looking for doesn't exist.</h1> |  | ||||||
|       <p>You may have mistyped the address or the page may have moved.</p> |  | ||||||
|     </div> |  | ||||||
|     <p>If you are the application owner check the logs for more information.</p> |  | ||||||
|   </div> |  | ||||||
| </body> |  | ||||||
| </html> |  | ||||||
|   | |||||||
| @@ -1,67 +1,2 @@ | |||||||
| <!DOCTYPE html> | <h1>422 Error</h1> | ||||||
| <html> | <p>Ethan, fix this</p> | ||||||
| <head> |  | ||||||
|   <title>The change you wanted was rejected (422)</title> |  | ||||||
|   <meta name="viewport" content="width=device-width,initial-scale=1"> |  | ||||||
|   <style> |  | ||||||
|   .rails-default-error-page { |  | ||||||
|     background-color: #EFEFEF; |  | ||||||
|     color: #2E2F30; |  | ||||||
|     text-align: center; |  | ||||||
|     font-family: arial, sans-serif; |  | ||||||
|     margin: 0; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page div.dialog { |  | ||||||
|     width: 95%; |  | ||||||
|     max-width: 33em; |  | ||||||
|     margin: 4em auto 0; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page div.dialog > div { |  | ||||||
|     border: 1px solid #CCC; |  | ||||||
|     border-right-color: #999; |  | ||||||
|     border-left-color: #999; |  | ||||||
|     border-bottom-color: #BBB; |  | ||||||
|     border-top: #B00100 solid 4px; |  | ||||||
|     border-top-left-radius: 9px; |  | ||||||
|     border-top-right-radius: 9px; |  | ||||||
|     background-color: white; |  | ||||||
|     padding: 7px 12% 0; |  | ||||||
|     box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page h1 { |  | ||||||
|     font-size: 100%; |  | ||||||
|     color: #730E15; |  | ||||||
|     line-height: 1.5em; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page div.dialog > p { |  | ||||||
|     margin: 0 0 1em; |  | ||||||
|     padding: 1em; |  | ||||||
|     background-color: #F7F7F7; |  | ||||||
|     border: 1px solid #CCC; |  | ||||||
|     border-right-color: #999; |  | ||||||
|     border-left-color: #999; |  | ||||||
|     border-bottom-color: #999; |  | ||||||
|     border-bottom-left-radius: 4px; |  | ||||||
|     border-bottom-right-radius: 4px; |  | ||||||
|     border-top-color: #DADADA; |  | ||||||
|     color: #666; |  | ||||||
|     box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |  | ||||||
|   } |  | ||||||
|   </style> |  | ||||||
| </head> |  | ||||||
|  |  | ||||||
| <body class="rails-default-error-page"> |  | ||||||
|   <!-- This file lives in public/422.html --> |  | ||||||
|   <div class="dialog"> |  | ||||||
|     <div> |  | ||||||
|       <h1>The change you wanted was rejected.</h1> |  | ||||||
|       <p>Maybe you tried to change something you didn't have access to.</p> |  | ||||||
|     </div> |  | ||||||
|     <p>If you are the application owner check the logs for more information.</p> |  | ||||||
|   </div> |  | ||||||
| </body> |  | ||||||
| </html> |  | ||||||
|   | |||||||
| @@ -1,66 +1,2 @@ | |||||||
| <!DOCTYPE html> | <h1>500 Error</h1> | ||||||
| <html> | <p>Ethan, fix this</p> | ||||||
| <head> |  | ||||||
|   <title>We're sorry, but something went wrong (500)</title> |  | ||||||
|   <meta name="viewport" content="width=device-width,initial-scale=1"> |  | ||||||
|   <style> |  | ||||||
|   .rails-default-error-page { |  | ||||||
|     background-color: #EFEFEF; |  | ||||||
|     color: #2E2F30; |  | ||||||
|     text-align: center; |  | ||||||
|     font-family: arial, sans-serif; |  | ||||||
|     margin: 0; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page div.dialog { |  | ||||||
|     width: 95%; |  | ||||||
|     max-width: 33em; |  | ||||||
|     margin: 4em auto 0; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page div.dialog > div { |  | ||||||
|     border: 1px solid #CCC; |  | ||||||
|     border-right-color: #999; |  | ||||||
|     border-left-color: #999; |  | ||||||
|     border-bottom-color: #BBB; |  | ||||||
|     border-top: #B00100 solid 4px; |  | ||||||
|     border-top-left-radius: 9px; |  | ||||||
|     border-top-right-radius: 9px; |  | ||||||
|     background-color: white; |  | ||||||
|     padding: 7px 12% 0; |  | ||||||
|     box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page h1 { |  | ||||||
|     font-size: 100%; |  | ||||||
|     color: #730E15; |  | ||||||
|     line-height: 1.5em; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   .rails-default-error-page div.dialog > p { |  | ||||||
|     margin: 0 0 1em; |  | ||||||
|     padding: 1em; |  | ||||||
|     background-color: #F7F7F7; |  | ||||||
|     border: 1px solid #CCC; |  | ||||||
|     border-right-color: #999; |  | ||||||
|     border-left-color: #999; |  | ||||||
|     border-bottom-color: #999; |  | ||||||
|     border-bottom-left-radius: 4px; |  | ||||||
|     border-bottom-right-radius: 4px; |  | ||||||
|     border-top-color: #DADADA; |  | ||||||
|     color: #666; |  | ||||||
|     box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |  | ||||||
|   } |  | ||||||
|   </style> |  | ||||||
| </head> |  | ||||||
|  |  | ||||||
| <body class="rails-default-error-page"> |  | ||||||
|   <!-- This file lives in public/500.html --> |  | ||||||
|   <div class="dialog"> |  | ||||||
|     <div> |  | ||||||
|       <h1>We're sorry, but something went wrong.</h1> |  | ||||||
|     </div> |  | ||||||
|     <p>If you are the application owner check the logs for more information.</p> |  | ||||||
|   </div> |  | ||||||
| </body> |  | ||||||
| </html> |  | ||||||
|   | |||||||
| @@ -680,6 +680,12 @@ babel-plugin-transform-regenerator@^6.22.0: | |||||||
|   dependencies: |   dependencies: | ||||||
|     regenerator-transform "^0.10.0" |     regenerator-transform "^0.10.0" | ||||||
|  |  | ||||||
|  | babel-plugin-transform-runtime@^6.23.0: | ||||||
|  |   version "6.23.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/babel-plugin-transform-runtime/-/babel-plugin-transform-runtime-6.23.0.tgz#88490d446502ea9b8e7efb0fe09ec4d99479b1ee" | ||||||
|  |   dependencies: | ||||||
|  |     babel-runtime "^6.22.0" | ||||||
|  |  | ||||||
| babel-plugin-transform-strict-mode@^6.24.1: | babel-plugin-transform-strict-mode@^6.24.1: | ||||||
|   version "6.24.1" |   version "6.24.1" | ||||||
|   resolved "https://registry.yarnpkg.com/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz#d5faf7aa578a65bbe591cf5edae04a0c67020758" |   resolved "https://registry.yarnpkg.com/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz#d5faf7aa578a65bbe591cf5edae04a0c67020758" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user