Pen Settings

HTML

CSS

CSS Base

Vendor Prefixing

Add External Stylesheets/Pens

Any URLs added here will be added as <link>s in order, and before the CSS in the editor. You can use the CSS from another Pen by using its URL and the proper URL extension.

+ add another resource

JavaScript

Babel includes JSX processing.

Add External Scripts/Pens

Any URL's added here will be added as <script>s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.

+ add another resource

Packages

Add Packages

Search for and use JavaScript packages from npm here. By selecting a package, an import statement will be added to the top of the JavaScript editor for this package.

Behavior

Auto Save

If active, Pens will autosave every 30 seconds after being saved once.

Auto-Updating Preview

If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.

Format on Save

If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.

Editor Settings

Code Indentation

Want to change your Syntax Highlighting theme, Fonts and more?

Visit your global Editor Settings.

HTML

              
                <!--
Follow me on
Dribbble: https://dribbble.com/colinspencedesign
Codepen: https://codepen.io/colinspencedesign
Facebook: https://facebook.com/colinspencedesign
-->

<div class="container">
  <div class="modal-wrapper">
    <div class="profile-img">
      <div class="profile-add"></div>
    </div>
    <div class="load-gif">
      <div>Sending...</div>
    </div>
    <div class="text-wrapper show">
      <div class="nav">
        <div class="login">Login</div>
        <div class="sign-up selected">Sign Up</div>
      </div>
      <form class="full-name">
        <div class="form-title">Full Name</div>
        <input class="content"></input>
      </form>
      <form class="email">
        <div class="form-title">Email</div>
        <input class="content"></input>
      </form>
      <form class="password">
        <div class="security hide">
          <div class="security-type">
            <div class="security-level"><span class="secureValue"></span>%</div>
            <div class="secure">secure</div>
          </div>
          <div class="fill circle"></div>
          <div class="cover circle"></div>
          <div class="background circle"></div>
        </div>
        <div class="form-title">Password</div>
        <input type="password" class="content"></input>
      </form>
      <form class="retype">
        <div class="form-title">Retype Password</div>
        <input type="password" class="content"></input>
      </form>
      <div class="button">Submit</div>
      <div class="forget">Forget your password?</div>
    </div>
  </div>
  <div class="overlay"></div>
</div>

[[[https://codepen.io/colinspencedesign/pen/wGBJpp]]]
              
            
!

CSS

              
                @import "bourbon"

/* -------- MIXINS -------- */
$emerald: #19CC8B
$lightGrey: #515866
$darkGrey: #2A2D33
$red: #BC3E48
$yellow: #B8B136
$font: "Avenir", sans-serif
$z: 10000
$ovlydur: 0.5s
$blankImg: url("https://s16.postimg.org/umce299tt/blank_Portrait_S_1.png?noCache=1455855743")
$plusSign: url("https://s16.postimg.org/5rsw86ozl/plus_sign.png?noCache=1455855743")
$colin: url("https://s16.postimg.org/dn3fmzym9/Colin_Portrait_S_1.png?noCache=1455855743")
/* ------------------------ */

.overlay
  z-index: $z - 1
  position: fixed
  top: 0
  left: 0
  right: 0
  bottom: 0
  background: $emerald

.modal-wrapper
  z-index: $z
  position: fixed
  left: 50%
  top: 50%
  @include transform(translate(-50%, -50%))
  width: 400px
  background-color: $darkGrey
  border-radius: 40px
  font-family: $font
  color: $lightGrey
  box-shadow: 0 40px 80px rgba(0,0,0,0.5)

.profile-img
  position: absolute
  background-image: $blankImg
  background-repeat: no-repeat
  background-size: 90%
  background-position: 50% 113%
  background-color: tint($lightGrey, 10%)
  border-radius: 50%
  width: 110px
  height: 110px
  border: 4px solid $lightGrey
  left: 50%
  @include transform(translate(-50%, -50%))
  &.profile-pic
    background-image: $colin
    background-size: contain

.profile-add
  background-image: $plusSign
  background-size: contain
  background-repeat: no-repeat
  background-position: center
  border-radius: 50%
  width: 20px
  height: 20px
  position: absolute
  bottom: 5px
  right: 5px
  cursor: pointer
  @include transition(all 0.25s ease)
  &:hover
    @include filter(brightness(0.8))
    @include transform(scale(1.2))

.load-gif
  position: absolute
  background: url("http://www.wallies.com/filebin/images/loading_apple.gif")
  background-size: contain
  background-repeat: no-repeat
  background-position: center
  width: 60px
  height: 60px
  text-align: center
  top: 50%
  left: 50%
  @include transform(translate(-50%, -50%))
  @include transition(opacity 0.25s)
  opacity: 0
  > div
    margin-top: 70px
    color: rgba(255,255,255,0.7)
  &.show
    opacity: 1

.text-wrapper
  margin: 40px
  -webkit-font-smoothing: antialiased
  opacity: 0
  @include transition(opacity 0.25s)
  &.show
    opacity: 1

.nav
  font-size: 21px
  font-weight: 600
  text-align: center
  margin: 80px 0 25px
  height: 30px
  width: 100%
  div
    -webkit-user-select: none
    padding-bottom: 8px
    border-bottom: 2px solid $lightGrey
    width: 50%
    float: left
    cursor: pointer
    &:hover
    color: tint($lightGrey, 10%)
    border-bottom: 2px solid tint($lightGrey, 10%)
    &.selected
      color: #fff
      font-weight: 900
      border-bottom: 4px solid #fff

form
  margin: 30px 0
  height: 58px
  overflow: hidden
  @include transition(opacity 0.75s ease, transform 1s, all 0.25s)
  opacity: 1
  @include transform(scaleY(1))
  &.ani-hide
    @include transition(opacity 0.5s ease, transform 0.75s, height 0.25s)
    @include transform(scaleY(0))
    height: 0
    margin: 0
    opacity: 0

.form-title
  text-transform: uppercase
  font-size: 10px
  font-weight: 600
  padding: 0 10px 2px
  letter-spacing: 0.5px

.content
  font: 500 18px/40px $font
  height: 40px
  padding: 0 10px
  color: #fff
  background: $lightGrey
  border: none
  @include calc(width, "100% - 20px")
  border-radius: 10px
  &:focus
    outline: none
    background: tint($lightGrey, 10%)

.security
  position: absolute
  @include transform(translateY(5px))
  right: -5px
  width: 60px
  height: 60px
  opacity: 1
  &.hide
    opacity: 0

.circle
  border-radius: 50%
  width: 60px
  height: 60px
  position: absolute
  top: 50%
  left: 50%
  @include transition(background 0.25s ease)
  @include transform(translate(-50%, -50%))
  &.background
    z-index: $z - 1
    background: $emerald
  &.fill
    z-index: $z
  &.cover
    z-index: $z
    background: $darkGrey
    width: 50px
    height: 50px

.security-type
  z-index: $z + 1
  text-align: center
  line-height: 90%
  position: absolute
  color: $emerald
  top: 50%
  left: 50%
  @include transform(translate(-48%, -40%))

.security-level
  font-weight: 900

.secure
  font-weight: 300
  font-size: 8px
  letter-spacing: 1px
  text-transform: uppercase

.password .content
  color: #fff
 
.forget
  text-align: center
  font-size: 11px
  font-weight: 800
  text-transform: uppercase
  width: 180px
  letter-spacing: 0.5px
  margin: 0 auto
  padding: 3px
  border-bottom: 1px solid $lightGrey
  cursor: pointer
  @include transition(opacity 0.5s, margin 0.5s 0.5s)
  &:hover
    color: tint($lightGrey, 10%)
    border-bottom: 1px solid tint($lightGrey, 10%)
  &.selected
    @include transition(opacity 0.5s)
    opacity: 1
    height: 0
    padding: 0

.button
  color: #fff
  background: $emerald
  margin: 0 auto 20px
  border-radius: 10px
  font-weight: 800
  width: 170px
  height: 40px
  line-height: 40px
  text-align: center
  display: block
  cursor: pointer
  @include transition(background 0.25s ease)
  &:hover
    background: shade($emerald, 15%)

.text, .text a, .icons a
  color: #fff
.text a:hover, .icons a:hover
  color: $lightGrey
              
            
!

JS

              
                login = $(".login")
signup = $(".sign-up")
forget = $(".forget")
submit = $('.button')
emerald = "#19CC8B"
red = "#BC3E48"
yellow = "#B8B136"
lightGrey = "#515866"
darkGrey = "#2A2D33"

toLogin = ->
  $(".security").addClass("hide")
  $(".full-name, .retype").addClass("ani-hide")
  $(".password, .password div").removeClass("ani-hide")
  login.addClass("selected")
  signup.removeClass("selected")
  emailVerify()
  forget.show()
  login.html("Login")
  signup.html("Sign Up")

toSignup = ->
  passwordSecure()
  $(".full-name, .retype, .password").removeClass("ani-hide")
  signup.addClass("selected")
  login.removeClass("selected")
  emailVerify()
  forget.hide()
  login.html("Login")
  signup.html("Sign Up")

toForget = ->
  $(".full-name, .full-name div, .retype, .retype div, .password, .password div .forget").addClass("ani-hide")
  signup.removeClass("selected")
  login.addClass("selected")
  emailVerify()
  forget.hide()
  login.html("Reset Password")
  signup.html("Back")

emailVerify = ->
  if $(".login").hasClass("selected")
    checkInterval = 0
    myInterval = setInterval (->
      if $(".email .content").val().length >= 18
        $(".profile-img").addClass("profile-pic")
        $(".profile-add").hide()
        clearInterval(myInterval)
      if checkInterval == 250
        clearInterval(myInterval)
      checkInterval++
    ), 250
  else
    $(".profile-add").show()
    $(".profile-img").removeClass("profile-pic")

passwordSecure = ->
  checkInterval = 0
  myInterval = setInterval (->
    value = $(".password .content").val()
    if value.length > 0 && value.length < 4
      color = red
      backFill = red
    else if value.length >= 5 && value.length < 7
      color = yellow
      backFill = yellow
    else if value.length >= 8
      color = emerald
      backFill = emerald
    if value.length > 0
      $(".security").removeClass("hide")
    else
      $(".security").addClass("hide")
    secureVal = value.length * 9
    if secureVal >= 100
      secureVal = 100
    if value.length <= 5
      pie1 = (value.length * 36) + 90
      pieColor = lightGrey
    else if value.length >= 5 && value.length <= 9
      pieColor = color
      pie1 = (value.length * 36) - 90
    else
      secureVal = 90
      pie1 = 270
    $(".secureValue").html(secureVal)
    console.log pie1 + " " + secureVal
    $(".password .content, .password .security-type").css("color", "#{color}")
    $(".circle.background").css("background", "#{backFill}")
    $(".password .fill").css
      background: "linear-gradient(#{pie1}deg, transparent 50%, #{pieColor} 50%), linear-gradient(90deg, #{lightGrey} 50%, transparent 50%)"
    if checkInterval == 250
      clearInterval(myInterval)
    login.click ->
      $(".password .content").css("color", "#fff")
      clearInterval(myInterval)
    checkInterval++
  ), 250

login.click ->
  if !login.hasClass("selected")
    toLogin()

signup.click ->
  if $(".password").hasClass("ani-hide")
    toLogin()
  else if !signup.hasClass("selected")
    toSignup()

submit.click ->
  if $(".password").hasClass("ani-hide")
    $(".text-wrapper").removeClass("show")
    $(".load-gif").addClass("show")
    setTimeout (->
      toLogin()
      $(".text-wrapper").addClass("show")
      $(".load-gif").removeClass("show")
    ), 2500

forget.click ->
  toForget()

$(".password .content").click ->
  if $(".sign-up").hasClass("selected")
    passwordSecure() 

$(".email .content").click =>
  emailVerify()
              
            
!
999px

Console