Showing
8 changed files
with
300 additions
and
8 deletions
| ... | @@ -12,6 +12,7 @@ gem 'paper_trail' | ... | @@ -12,6 +12,7 @@ gem 'paper_trail' |
| 12 | gem 'will_paginate' | 12 | gem 'will_paginate' |
| 13 | gem 'nested_form' | 13 | gem 'nested_form' |
| 14 | gem 'simple_form' | 14 | gem 'simple_form' |
| 15 | +gem 'pry' | ||
| 15 | 16 | ||
| 16 | 17 | ||
| 17 | # Bundle edge Rails instead: gem 'rails', github: 'rails/rails' | 18 | # Bundle edge Rails instead: gem 'rails', github: 'rails/rails' | ... | ... |
| ... | @@ -72,6 +72,7 @@ GEM | ... | @@ -72,6 +72,7 @@ GEM |
| 72 | bootstrap-switch-rails (3.3.3) | 72 | bootstrap-switch-rails (3.3.3) |
| 73 | builder (3.2.3) | 73 | builder (3.2.3) |
| 74 | byebug (10.0.2) | 74 | byebug (10.0.2) |
| 75 | + coderay (1.1.2) | ||
| 75 | coffee-rails (4.2.2) | 76 | coffee-rails (4.2.2) |
| 76 | coffee-script (>= 2.2.0) | 77 | coffee-script (>= 2.2.0) |
| 77 | railties (>= 4.0.0) | 78 | railties (>= 4.0.0) |
| ... | @@ -121,6 +122,9 @@ GEM | ... | @@ -121,6 +122,9 @@ GEM |
| 121 | paranoia (2.4.1) | 122 | paranoia (2.4.1) |
| 122 | activerecord (>= 4.0, < 5.3) | 123 | activerecord (>= 4.0, < 5.3) |
| 123 | pg (1.0.0) | 124 | pg (1.0.0) |
| 125 | + pry (0.11.3) | ||
| 126 | + coderay (~> 1.1.0) | ||
| 127 | + method_source (~> 0.9.0) | ||
| 124 | puma (3.11.4) | 128 | puma (3.11.4) |
| 125 | rack (2.0.5) | 129 | rack (2.0.5) |
| 126 | rack-test (0.6.3) | 130 | rack-test (0.6.3) |
| ... | @@ -236,6 +240,7 @@ DEPENDENCIES | ... | @@ -236,6 +240,7 @@ DEPENDENCIES |
| 236 | paper_trail | 240 | paper_trail |
| 237 | paranoia | 241 | paranoia |
| 238 | pg | 242 | pg |
| 243 | + pry | ||
| 239 | puma (~> 3.0) | 244 | puma (~> 3.0) |
| 240 | rails (~> 5.0.6) | 245 | rails (~> 5.0.6) |
| 241 | sass-rails (~> 5.0) | 246 | sass-rails (~> 5.0) | ... | ... |
app/assets/stylesheets/login.scss
0 → 100644
| 1 | +form.login { | ||
| 2 | + * { box-sizing:border-box; } | ||
| 3 | + width: 380px; | ||
| 4 | + // margin: 4em auto; | ||
| 5 | + padding: 3em 2em 2em 2em; | ||
| 6 | + background: #fafafa; | ||
| 7 | + border: 1px solid #ebebeb; | ||
| 8 | + box-shadow: rgba(0,0,0,0.14902) 0px 1px 1px 0px,rgba(0,0,0,0.09804) 0px 1px 2px 0px; | ||
| 9 | + | ||
| 10 | + .group { | ||
| 11 | + position: relative; | ||
| 12 | + margin-bottom: 45px; | ||
| 13 | + } | ||
| 14 | + | ||
| 15 | + input { | ||
| 16 | + font-size: 18px; | ||
| 17 | + padding: 10px 10px 10px 5px; | ||
| 18 | + -webkit-appearance: none; | ||
| 19 | + display: block; | ||
| 20 | + background: #fafafa; | ||
| 21 | + color: #636363; | ||
| 22 | + width: 100%; | ||
| 23 | + border: none; | ||
| 24 | + border-radius: 0; | ||
| 25 | + border-bottom: 1px solid #757575; | ||
| 26 | + } | ||
| 27 | + | ||
| 28 | + input:focus { outline: none; } | ||
| 29 | + | ||
| 30 | + | ||
| 31 | + /* Label */ | ||
| 32 | + | ||
| 33 | + label { | ||
| 34 | + color: #999; | ||
| 35 | + font-size: 18px; | ||
| 36 | + font-weight: normal; | ||
| 37 | + position: absolute; | ||
| 38 | + pointer-events: none; | ||
| 39 | + left: 5px; | ||
| 40 | + top: 10px; | ||
| 41 | + transition: all 0.2s ease; | ||
| 42 | + } | ||
| 43 | + | ||
| 44 | + | ||
| 45 | + /* active */ | ||
| 46 | + | ||
| 47 | + input:focus ~ label, input.used ~ label { | ||
| 48 | + top: -20px; | ||
| 49 | + transform: scale(.75); left: -2px; | ||
| 50 | + /* font-size: 14px; */ | ||
| 51 | + color: #4a89dc; | ||
| 52 | + } | ||
| 53 | + | ||
| 54 | + | ||
| 55 | + /* Underline */ | ||
| 56 | + | ||
| 57 | + .bar { | ||
| 58 | + position: relative; | ||
| 59 | + display: block; | ||
| 60 | + width: 100%; | ||
| 61 | + } | ||
| 62 | + | ||
| 63 | + .bar:before, .bar:after { | ||
| 64 | + content: ''; | ||
| 65 | + height: 2px; | ||
| 66 | + width: 0; | ||
| 67 | + bottom: 1px; | ||
| 68 | + position: absolute; | ||
| 69 | + background: #4a89dc; | ||
| 70 | + transition: all 0.2s ease; | ||
| 71 | + } | ||
| 72 | + | ||
| 73 | + .bar:before { left: 50%; } | ||
| 74 | + | ||
| 75 | + .bar:after { right: 50%; } | ||
| 76 | + | ||
| 77 | + | ||
| 78 | + /* active */ | ||
| 79 | + | ||
| 80 | + input:focus ~ .bar:before, input:focus ~ .bar:after { width: 50%; } | ||
| 81 | + | ||
| 82 | + | ||
| 83 | + /* Highlight */ | ||
| 84 | + | ||
| 85 | + .highlight { | ||
| 86 | + position: absolute; | ||
| 87 | + height: 60%; | ||
| 88 | + width: 100px; | ||
| 89 | + top: 25%; | ||
| 90 | + left: 0; | ||
| 91 | + pointer-events: none; | ||
| 92 | + opacity: 0.5; | ||
| 93 | + } | ||
| 94 | + | ||
| 95 | + | ||
| 96 | + /* active */ | ||
| 97 | + | ||
| 98 | + input:focus ~ .highlight { | ||
| 99 | + animation: inputHighlighter 0.3s ease; | ||
| 100 | + } | ||
| 101 | + | ||
| 102 | + | ||
| 103 | + /* Animations */ | ||
| 104 | + | ||
| 105 | + @keyframes inputHighlighter { | ||
| 106 | + from { background: #4a89dc; } | ||
| 107 | + to { width: 0; background: transparent; } | ||
| 108 | + } | ||
| 109 | + | ||
| 110 | + | ||
| 111 | + /* Button */ | ||
| 112 | + | ||
| 113 | + .button { | ||
| 114 | + position: relative; | ||
| 115 | + display: inline-block; | ||
| 116 | + padding: 12px 24px; | ||
| 117 | + margin: .3em 0 1em 0; | ||
| 118 | + width: 100%; | ||
| 119 | + vertical-align: middle; | ||
| 120 | + color: #fff; | ||
| 121 | + font-size: 16px; | ||
| 122 | + line-height: 20px; | ||
| 123 | + -webkit-font-smoothing: antialiased; | ||
| 124 | + text-align: center; | ||
| 125 | + letter-spacing: 1px; | ||
| 126 | + background: transparent; | ||
| 127 | + border: 0; | ||
| 128 | + border-bottom: 2px solid #3160B6; | ||
| 129 | + cursor: pointer; | ||
| 130 | + transition: all 0.15s ease; | ||
| 131 | + } | ||
| 132 | + .button:focus { outline: 0; } | ||
| 133 | + | ||
| 134 | + | ||
| 135 | + /* Button modifiers */ | ||
| 136 | + | ||
| 137 | + .buttonBlue { | ||
| 138 | + background: #4a89dc; | ||
| 139 | + text-shadow: 1px 1px 0 rgba(39, 110, 204, .5); | ||
| 140 | + } | ||
| 141 | + | ||
| 142 | + .buttonBlue:hover { background: #357bd8; } | ||
| 143 | + | ||
| 144 | + | ||
| 145 | + /* Ripples container */ | ||
| 146 | + | ||
| 147 | + .ripples { | ||
| 148 | + position: absolute; | ||
| 149 | + top: 0; | ||
| 150 | + left: 0; | ||
| 151 | + width: 100%; | ||
| 152 | + height: 100%; | ||
| 153 | + overflow: hidden; | ||
| 154 | + background: transparent; | ||
| 155 | + } | ||
| 156 | + | ||
| 157 | + | ||
| 158 | + /* Ripples circle */ | ||
| 159 | + | ||
| 160 | + .ripplesCircle { | ||
| 161 | + position: absolute; | ||
| 162 | + top: 50%; | ||
| 163 | + left: 50%; | ||
| 164 | + transform: translate(-50%, -50%); | ||
| 165 | + opacity: 0; | ||
| 166 | + width: 0; | ||
| 167 | + height: 0; | ||
| 168 | + border-radius: 50%; | ||
| 169 | + background: rgba(255, 255, 255, 0.25); | ||
| 170 | + } | ||
| 171 | + | ||
| 172 | + .ripples.is-active .ripplesCircle { | ||
| 173 | + animation: ripples .4s ease-in; | ||
| 174 | + } | ||
| 175 | + | ||
| 176 | + | ||
| 177 | + /* Ripples animation */ | ||
| 178 | + | ||
| 179 | + @keyframes ripples { | ||
| 180 | + 0% { opacity: 0; } | ||
| 181 | + | ||
| 182 | + 25% { opacity: 1; } | ||
| 183 | + | ||
| 184 | + 100% { | ||
| 185 | + width: 200%; | ||
| 186 | + padding-bottom: 200%; | ||
| 187 | + opacity: 0; | ||
| 188 | + } | ||
| 189 | + } | ||
| 190 | + | ||
| 191 | + footer { text-align: center; } | ||
| 192 | + | ||
| 193 | + footer p { | ||
| 194 | + color: #888; | ||
| 195 | + font-size: 13px; | ||
| 196 | + letter-spacing: .4px; | ||
| 197 | + } | ||
| 198 | + | ||
| 199 | + footer a { | ||
| 200 | + color: #4a89dc; | ||
| 201 | + text-decoration: none; | ||
| 202 | + transition: all .2s ease; | ||
| 203 | + } | ||
| 204 | + | ||
| 205 | + footer a:hover { | ||
| 206 | + color: #666; | ||
| 207 | + text-decoration: underline; | ||
| 208 | + } | ||
| 209 | + | ||
| 210 | + footer img { | ||
| 211 | + width: 80px; | ||
| 212 | + transition: all .2s ease; | ||
| 213 | + } | ||
| 214 | + | ||
| 215 | + footer img:hover { opacity: .83; } | ||
| 216 | + | ||
| 217 | + footer img:focus , footer a:focus { outline: none; } | ||
| 218 | + | ||
| 219 | +} |
| 1 | +body { | ||
| 2 | + font-family: Helvetica, sans-serif; | ||
| 3 | + background: #eee; | ||
| 4 | + -webkit-font-smoothing: antialiased; | ||
| 5 | +} | ||
| 6 | + | ||
| 7 | +h1, h3 { font-weight: 300; } | ||
| 8 | + | ||
| 9 | +h1 { color: #636363; } | ||
| 10 | +hgroup { | ||
| 11 | + text-align:center; | ||
| 12 | + margin-top: 4em; | ||
| 13 | +} | ||
| 1 | // Divs | 14 | // Divs |
| 2 | .container { | 15 | .container { |
| 3 | display: grid; | 16 | display: grid; |
| ... | @@ -25,4 +38,4 @@ | ... | @@ -25,4 +38,4 @@ |
| 25 | 38 | ||
| 26 | .right { | 39 | .right { |
| 27 | grid-column: 3; | 40 | grid-column: 3; |
| 28 | -} | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 41 | +} | ... | ... |
| ... | @@ -2,6 +2,7 @@ | ... | @@ -2,6 +2,7 @@ |
| 2 | class Bet < ApplicationRecord | 2 | class Bet < ApplicationRecord |
| 3 | validates :score_local, :score_visit, presence: true | 3 | validates :score_local, :score_visit, presence: true |
| 4 | belongs_to :user, inverse_of: :bets | 4 | belongs_to :user, inverse_of: :bets |
| 5 | + belongs_to :match, inverse_of: :bets | ||
| 5 | enum result: [:visit, :tie, :local] | 6 | enum result: [:visit, :tie, :local] |
| 6 | 7 | ||
| 7 | scope :active, -> { joins(match: :pool).where(pools: { active: true }) } | 8 | scope :active, -> { joins(match: :pool).where(pools: { active: true }) } | ... | ... |
| 1 | += form_tag login_path, class: 'login' do | ||
| 2 | + - if flash[:error] | ||
| 3 | + div class="group" | ||
| 4 | + = flash[:error] | ||
| 5 | + div class="hgroup" | ||
| 6 | + h1 Sign in to manage your bets! | ||
| 7 | + div class="group" | ||
| 8 | + input type="email" required=true name='key' autofocus=true value=params[:key] | ||
| 9 | + span class="highlight" | ||
| 10 | + span class="bar" | ||
| 11 | + label Email | ||
| 12 | + div class="group" | ||
| 13 | + input type="password" required=true name='password' | ||
| 14 | + span class="highlight" | ||
| 15 | + span class="bar" | ||
| 16 | + label Password | ||
| 17 | + button type="submit" class="button buttonBlue" | ||
| 18 | + | Sign in | ||
| 19 | + div class="ripples buttonRipples" | ||
| 20 | + span class="ripplesCircle" | ||
| 21 | +javascript: | ||
| 22 | + $('input').blur(function() { | ||
| 23 | + var $this = $(this); | ||
| 24 | + if ($this.val()) | ||
| 25 | + $this.addClass('used'); | ||
| 26 | + else | ||
| 27 | + $this.removeClass('used'); | ||
| 28 | + }); | ||
| 29 | + | ||
| 30 | + var $ripples = $('.ripples'); | ||
| 31 | + | ||
| 32 | + $ripples.on('click.Ripples', function(e) { | ||
| 33 | + | ||
| 34 | + var $this = $(this); | ||
| 35 | + var $offset = $this.parent().offset(); | ||
| 36 | + var $circle = $this.find('.ripplesCircle'); | ||
| 37 | + | ||
| 38 | + var x = e.pageX - $offset.left; | ||
| 39 | + var y = e.pageY - $offset.top; | ||
| 40 | + | ||
| 41 | + $circle.css({ | ||
| 42 | + top: y + 'px', | ||
| 43 | + left: x + 'px' | ||
| 44 | + }); | ||
| 45 | + | ||
| 46 | + $this.addClass('is-active'); | ||
| 47 | + | ||
| 48 | + }); | ||
| 49 | + | ||
| 50 | + $ripples.on('animationend webkitAnimationEnd mozAnimationEnd oanimationend MSAnimationEnd', function(e) { | ||
| 51 | + $(this).removeClass('is-active'); | ||
| 52 | + }); | ||
| 53 | + | ... | ... |
| 1 | .container | 1 | .container |
| 2 | - - if @current_user | 2 | + - if current_user |
| 3 | .navbar | 3 | .navbar |
| 4 | .left.content | 4 | .left.content |
| 5 | - - if @current_user | 5 | + - if current_user |
| 6 | - = render 'login' | ||
| 7 | - - else | ||
| 8 | = render 'results' | 6 | = render 'results' |
| 7 | + - else | ||
| 8 | + = render 'login' | ||
| 9 | .center.content | 9 | .center.content |
| 10 | = render 'leaderboard' | 10 | = render 'leaderboard' |
| 11 | .right.content | 11 | .right.content |
| 12 | - = render 'upcoming_matches' | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 12 | + = render 'upcoming_matches' | ... | ... |
| ... | @@ -7,5 +7,5 @@ | ... | @@ -7,5 +7,5 @@ |
| 7 | # Character.create(name: 'Luke', movie: movies.first) | 7 | # Character.create(name: 'Luke', movie: movies.first) |
| 8 | admin = Role.create(name: 'SuperAdmin', erasable: false) | 8 | admin = Role.create(name: 'SuperAdmin', erasable: false) |
| 9 | player = Role.create(name: 'Player', erasable: false) | 9 | player = Role.create(name: 'Player', erasable: false) |
| 10 | -User.new(name: 'Iker', mail: 'i.narvaez@ukko.mx', password: '12345', password_confirmation: '12345', roles: [admin, player]) | 10 | +User.create!(name: 'Iker', mail: 'i.narvaez@ukko.mx', password: '12345', password_confirmation: '12345', roles: [admin, player]) |
| 11 | -User.new(name: 'Iker', mail: 'p.sanches@ukko.mx', password: '12345', password_confirmation: '12345', roles: [admin, player]) | 11 | +User.create!(name: 'Iker', mail: 'p.sanches@ukko.mx', password: '12345', password_confirmation: '12345', roles: [admin, player]) | ... | ... |
-
Please register or login to post a comment