HTML5, CSS3 & JS Experiments

By Martin Ivanov

Extended Password Input

AcidJs.XPassword is a HTML5 Web Component password on steriods, allowing enabling Windows 8-like "reveal password" behavior out of the box without any JavaScript, easy like a simple HTML tag:

<acidjs-xpassword></acidjs-xpassword>

Type a password, and click the eye to reveal it.

Demo

Default X-Password Input

 

X-Password Input with all Properties Set

 

Enabled X-Password Input with Default Value

 

Enabled X-Password Input With Revealed Value

 

Disabled X-Password Input

 

Readonly X-Password Input

 

Register Mozilla's X-Tags

You need to do this just once, and add the directive either in the <head /> section or before the closing <body /> tag of the page.

<script src="AcidJs.XPassword/lib/x-tag-components.js"></script>

Register the Component on the Page via HTML5 @import

You need to do this just once, and add the directive either in the <head /> section or before the closing <body /> tag of the page.

<link rel="import" href="AcidJs.XPassword/classes/XPassword.html" />

HTML Attributes

Check the blogpost or the documentation in the distrubution file (the download link is at the top of the page).

JavaScript API: Methods, Getters and Setters

Check the blogpost or the documentation in the distrubution file (the download link is at the top of the page).

Usage and Code Insight

            
            <p>Default X-Password Input</p>
            <acidjs-xpassword></acidjs-xpassword>
            
            <p> </p>
            <p>X-Password Input with all Properties Set</p>

            <acidjs-xpassword 
                width="200"
                enabled="true"
                editable="true"
                name="pwd-01"
                id="pwd-01"
                value="lorem"
                placeholder="placeholder text"
                buttonhint="Reveal password">
            </acidjs-xpassword>
            
            <p> </p>
            <p>Enabled X-Password Input with Default Value<p>

            <acidjs-xpassword 
                width="500" 
                name="pwd-01" 
                id="pwd-01" 
                value="lorem">
            </acidjs-xpassword>

            <p> </p>
            <p>Enabled X-Password Input With Revealed Value</p>

            <acidjs-xpassword 
                width="400" 
                name="pwd-03" 
                id="pwd-03" 
                value="lorem" 
                visible="true">
            </acidjs-xpassword>

            <p> </p>
            <p>Disabled X-Password Input</p>

            <acidjs-xpassword 
                name="pwd-02"
                id="pwd-02"
                enabled="false">
            </acidjs-xpassword>

            <p> </p>
            <p>Readonly X-Password Input</p>

            <acidjs-xpassword 
                name="pwd-02" 
                id="pwd-02" 
                editable="false">
            </acidjs-xpassword>
            <p> </p>
            
        
/*
 * X-Password - Input on Steroids | HTML5 Web Component by Martin Ivanov (@wemakesitesnet)
 * More info regarding this exciting new technology: http://webcomponents.org/, http://www.x-tags.org/, http://www.polymer-project.org/
 * @author Martin Ivanov
 * @url developer website: http://wemakesites.net/
 * @url developer twitter: https://twitter.com/#!/wemakesitesnet
 * @url developer blog http://acidmartin.wordpress.com/
 **/

acidjs-xpassword input:disabled,
acidjs-xpassword input:disabled + button,
acidjs-xpassword input[readonly] + button,
acidjs-xpassword[visible="true"] button
{
    cursor: default;
}

acidjs-xpassword input:disabled + button,
acidjs-xpassword input[readonly] + button,
acidjs-xpassword[visible="true"] button
{
    opacity: .5;
    
    -webkit-pointer-events: none;
    -moz-pointer-events: none;
    pointer-events: none;
}

acidjs-xpassword,
acidjs-xpassword *
{
    display: inline-block;
    vertical-align: middle;
    margin: 0;
    padding: 0;
    outline: 0;
    
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

acidjs-xpassword input::-ms-clear,
acidjs-xpassword input::-ms-reveal
{
    display: none;
}

acidjs-xpassword button:-moz-focus-inner
{
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
}

acidjs-xpassword button::-moz-focus-inner
{
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
}

acidjs-xpassword input
{
    height: 32px;
    padding: 0 30px 0px 4px;
    font: normal 16px "Segoe UI", Arial, Sans-serif;
    border: solid 1px #000;
}

acidjs-xpassword button
{
    border: 0;
    margin: 0 0 0 -32px;
    width: 28px;
    height: 28px;
    background: url("") no-repeat center;
    background-size: cover;
    cursor: pointer;
}

acidjs-xpassword button:active
{
    -webkit-transform: scale(.9);
    -moz-transform: scale(.9);
    -ms-transform: scale(.9);
    -o-transform: scale(.9);
    transform: scale(.9);
}

acidjs-xpassword input:disabled
{
    border-color: #ccc;
    background: #fff;
}

acidjs-xpassword input::-webkit-input-placeholder
{
   color: #666;
   font-style: italic;
}

acidjs-xpassword input:-moz-placeholder 
{
   color: #666;
   font-style: italic;
}

acidjs-xpassword input::-moz-placeholder 
{
   color: #666;
   font-style: italic;
}

acidjs-xpassword input:-ms-input-placeholder 
{  
   color: #666;
   font-style: italic;
}

acidjs-xpassword input:-ms-placeholder 
{  
   color: #666;
   font-style: italic;
}

acidjs-xpassword input:placeholder 
{
   color: #666;
   font-style: italic;
}