Latest News

Sunday, 21 December 2014

Circular Animated Button

Add a Circular Animated Button on website or blogger. Let us follow the below steps.
Step 1: Go to Blogger Click the Dashboard then
Step 2: Now Click on Template->Edit HTML-> Proceed
Step 3: Now Find this code ]]></b:skin> by pressing Ctrl + F
Step 4: Copy the code from below and Paste it  Before/above ]]></b:skin>
article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block;}audio,canvas,video{display:inline-block;}audio:not([controls]){display:none;height:0;}[hidden]{display:none;}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;}body{margin:0;}a:focus{outline:thin dotted;}a:active,a:hover{outline:0;}h1{font-size:2em;margin:0.67em 0;}abbr[title]{border-bottom:1px dotted;}b,strong{font-weight:bold;}dfn{font-style:italic;}hr{-moz-box-sizing:content-box;box-sizing:content-box;height:0;}mark{background:#ff0;color:#000;}code,kbd,pre,samp{font-family:monospace,serif;font-size:1em;}pre{white-space:pre-wrap;}q{quotes:"\201C" "\201D" "\2018" "\2019";}small{font-size:80%;}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline;}sup{top:-0.5em;}sub{bottom:-0.25em;}img{border:0;}svg:not(:root){overflow:hidden;}figure{margin:0;}fieldset{border:1px solid #c0c0c0;margin:0 2px;padding:0.35em 0.625em 0.75em;}legend{border:0;padding:0;}button,input,select,textarea{font-family:inherit;font-size:100%;margin:0;}button,input{line-height:normal;}button,select{text-transform:none;}button,html input[type="button"],input[type="reset"],input[type="submit"]{-webkit-appearance:button;cursor:pointer;}button[disabled],html input[disabled]{cursor:default;}input[type="checkbox"],input[type="radio"]{box-sizing:border-box;padding:0;}input[type="search"]{-webkit-appearance:textfield;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box;}input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none;}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0;}textarea{overflow:auto;vertical-align:top;}table{border-collapse:collapse;border-spacing:0;}
*, *:after, *:before { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
.clearfix:before, .clearfix:after { content: ''; display: table; }
.clearfix:after { clear: both; }

body {
 background: #fff;
 color: #62706c;
 font-size: 100%;
 line-height: 1.25;
 padding: 25px 0;
 border-right: 25px solid #fff;
 border-left: 25px solid #fff;
 font-family: 'Lato', Arial, sans-serif;
}

body::before,
body::after {
 content: '';
 position: fixed;
 left: 0;
 top: 0;
 width: 100%;
 height: 25px;
 background: #fff;
 z-index: 99;
}

body::after {
 top: auto;
 bottom: 0;
}

a {
 color: rgba(0,0,0,0.3);
 text-decoration: none;
 outline: none;
}

a:hover, a:focus {
 color: rgba(0,0,0,0.6);
}

.Blogsitedesigns-header {
 margin: 0 auto;
 padding: 4em 1em;
 text-align: center;
}

.Blogsitedesigns-header h1 {
 margin: 0;
 font-weight: 300;
 font-size: 2.5em;
 position: relative;
}

.Blogsitedesigns-header h1 span {
 display: block;
 padding: 0 0 0.6em 0.1em;
 font-size: 0.6em;
 color: #aaa;
}

.Blogsitedesigns-header a {
 color: #1ECD97;
}

.Blogsitedesigns-header a:hover {
 color: #44524e;
}

/* To Navigation Style */
.Blogsitedesigns-top {
 width: 100%;
 top: 0;
 left: 0;
 text-transform: uppercase;
 font-weight: 700;
 font-size: 0.69em;
 line-height: 2.2;
 z-index: 1000;
 padding-top: 3px;
}

.Blogsitedesigns-top a {
 display: inline-block;
 padding: 0 1em;
 text-decoration: none;
 letter-spacing: 1px;
}

.Blogsitedesigns-top span.right {
 float: right;
}

.Blogsitedesigns-top span.right a {
 display: block;
 float: left;
}

.Blogsitedesigns-icon:before {
 margin: 0 4px;
 text-transform: none;
 font-weight: normal;
 font-style: normal;
 font-variant: normal;
 font-family: 'Blogsitedesignsicons';
 line-height: 1;
 speak: none;
 -webkit-font-smoothing: antialiased;
}

.Blogsitedesigns-icon-drop:before {
 content: "\e001";
}

.Blogsitedesigns-icon-prev:before {
 content: "\e004";
}

section {
 text-align: center;
 position: relative;
}

section h2 {
 color: #ccc;
 font-weight: 400;
 margin: 2em 0 0;
 font-size: 1.15em;
 padding: 0 1em;
}

.box {
 width: 100%;
 max-width: 720px;
 display: inline-block;
 padding: 3em 1em;
}

.box h3 {
 color: #aaa;
 font-size: 1em;
 text-transform: uppercase;
 letter-spacing: 1px;
 font-weight: 400;
 padding: 2em 0;
}

.related {
 padding: 10em 0;
}

.related p {
 font-size: 1.5em;
}

.related > a {
 border: 2px solid rgba(0,0,0,0.3);
 display: inline-block;
 text-align: center;
 margin: 20px 10px;
 padding: 25px;
 -webkit-transition: color 0.3s, border-color 0.3s;
 transition: color 0.3s, border-color 0.3s;
}

.related a:hover {
 border-color: rgba(0,0,0,0.6);
}

.related a img {
 max-width: 100%;
 opacity: 0.8;
 -webkit-transition: opacity 0.3s;
 transition: opacity 0.3s;
}

.related a:hover img,
.related a:active img {
 opacity: 1;
}

.related a h3 {
 margin: 0;
 padding: 0.5em 0 0.3em;
 max-width: 300px;
 text-align: left;
}

@media screen and (max-width: 26em) {
 .Blogsitedesigns-icon span {
  display: none;
 }
}
 /* Button container */
.progress-button {
 position: relative;
 display: inline-block;
 text-align: center;
 width: 45%;
 min-width: 250px;
 margin: 10px;
}

/* Button style */
.progress-button button {
 display: block;
 margin: 0 auto;
 padding: 0;
 width: 250px;
 height: 70px;
 border: 2px solid #1ECD97;
 border-radius: 40px;
 background: transparent;
 color: #1ECD97;
 letter-spacing: 1px;
 font-size: 18px;
 font-family: 'Montserrat', sans-serif;
 -webkit-tap-highlight-color: transparent;
 -webkit-transition: background-color 0.3s, color 0.3s, width 0.3s, border-width 0.3s, border-color 0.3s;
 transition: background-color 0.3s, color 0.3s, width 0.3s, border-width 0.3s, border-color 0.3s;
}

.progress-button button:hover {
 background-color: #1ECD97;
 color: #fff;
}

.progress-button button:focus {
 outline: none;
}

/* Text (transition for when returning to initial state) */
.progress-button button span {
 -webkit-transition: opacity 0.3s 0.1s;
 transition: opacity 0.3s 0.1s;
}

/* Common style of SVGs */
.progress-button svg {
 position: absolute;
 top: 0;
 left: 50%;
 -webkit-transform: translateX(-50%);
 transform: translateX(-50%);
 pointer-events: none;
}

.progress-button svg path {
 opacity: 0;
 fill: none;
}

.progress-button svg.progress-circle path {
 stroke: #1ECD97;
 stroke-width: 5;
}

.progress-button svg.checkmark path,
.progress-button svg.cross path {
 stroke: #fff;
 stroke-linecap: round;
 stroke-width: 4;
 -webkit-transition: opacity 0.1s;
 transition: opacity 0.1s;
}

/* Loading, success and error effects */
.loading.progress-button button {
 width: 70px; /* make a circle */
 border-width: 5px;
 border-color: #ddd;
 background-color: transparent;
 color: #fff;
}

.loading.progress-button span {
 -webkit-transition: opacity 0.15s;
 transition: opacity 0.15s;
}

.loading.progress-button span,
.success.progress-button span,
.error.progress-button span {
 opacity: 0; /* keep it hidden in all states */
}

.success.progress-button button,
.error.progress-button button {
 -webkit-transition: background-color 0.3s, width 0.3s, border-width 0.3s;
 transition: background-color 0.3s, width 0.3s, border-width 0.3s;
}

.success.progress-button button {
 border-color: #1ECD97;
 background-color: #1ECD97;
}

.error.progress-button button {
 border-color: #FB797E;
 background-color: #FB797E;
}

.loading.progress-button svg.progress-circle path,
.success.progress-button svg.checkmark path,
.error.progress-button svg.cross path {
 opacity: 1;
 -webkit-transition: stroke-dashoffset 0.3s;
 transition: stroke-dashoffset 0.3s;
}

/* Optional elastic effect for the width of the button */
.elastic.progress-button button {
 -webkit-transition: background-color 0.3s, color 0.3s, width 0.3s cubic-bezier(0.25, 0.25, 0.4, 1), border-width 0.3s, border-color 0.3s;
 -webkit-transition: background-color 0.3s, color 0.3s, width 0.3s cubic-bezier(0.25, 0.25, 0.4, 1.6), border-width 0.3s, border-color 0.3s;
 transition: background-color 0.3s, color 0.3s, width 0.3s cubic-bezier(0.25, 0.25, 0.4, 1.6), border-width 0.3s, border-color 0.3s;
}

.loading.elastic.progress-button button {
 -webkit-transition: background-color 0.3s, color 0.3s, width 0.3s cubic-bezier(0.6, 0, 0.75, 0.75), border-width 0.3s, border-color 0.3s;
 -webkit-transition: background-color 0.3s, color 0.3s, width 0.3s cubic-bezier(0.6, -0.6, 0.75, 0.75), border-width 0.3s, border-color 0.3s;
 transition: background-color 0.3s, color 0.3s, width 0.3s cubic-bezier(0.6, -0.6, 0.75, 0.75), border-width 0.3s, border-color 0.3s;
}
Step 5: Now Save Template then
Step 6: Now Find this code </head> by pressing Ctrl + F
Step 7: Copy the code from below and Paste it  Before/above </head>

 <script>
;window.Modernizr=function(a,b,c){function x(a){j.cssText=a}function y(a,b){return x(prefixes.join(a+";")+(b||""))}function z(a,b){return typeof a===b}function A(a,b){return!!~(""+a).indexOf(b)}function B(a,b){for(var d in a){var e=a[d];if(!A(e,"-")&&j[e]!==c)return b=="pfx"?e:!0}return!1}function C(a,b,d){for(var e in a){var f=b[a[e]];if(f!==c)return d===!1?a[e]:z(f,"function")?f.bind(d||b):f}return!1}function D(a,b,c){var d=a.charAt(0).toUpperCase()+a.slice(1),e=(a+" "+n.join(d+" ")+d).split(" ");return z(b,"string")||z(b,"undefined")?B(e,b):(e=(a+" "+o.join(d+" ")+d).split(" "),C(e,b,c))}var d="2.7.1",e={},f=!0,g=b.documentElement,h="modernizr",i=b.createElement(h),j=i.style,k,l={}.toString,m="Webkit Moz O ms",n=m.split(" "),o=m.toLowerCase().split(" "),p={},q={},r={},s=[],t=s.slice,u,v={}.hasOwnProperty,w;!z(v,"undefined")&&!z(v.call,"undefined")?w=function(a,b){return v.call(a,b)}:w=function(a,b){return b in a&&z(a.constructor.prototype[b],"undefined")},Function.prototype.bind||(Function.prototype.bind=function(b){var c=this;if(typeof c!="function")throw new TypeError;var d=t.call(arguments,1),e=function(){if(this instanceof e){var a=function(){};a.prototype=c.prototype;var f=new a,g=c.apply(f,d.concat(t.call(arguments)));return Object(g)===g?g:f}return c.apply(b,d.concat(t.call(arguments)))};return e}),p.csstransitions=function(){return D("transition")};for(var E in p)w(p,E)&&(u=E.toLowerCase(),e[u]=p[E](),s.push((e[u]?"":"no-")+u));return e.addTest=function(a,b){if(typeof a=="object")for(var d in a)w(a,d)&&e.addTest(d,a[d]);else{a=a.toLowerCase();if(e[a]!==c)return e;b=typeof b=="function"?b():b,typeof f!="undefined"&&f&&(g.className+=" "+(b?"":"no-")+a),e[a]=b}return e},x(""),i=k=null,function(a,b){function l(a,b){var c=a.createElement("p"),d=a.getElementsByTagName("head")[0]||a.documentElement;return c.innerHTML="x<style>"+b+"</style>",d.insertBefore(c.lastChild,d.firstChild)}function m(){var a=s.elements;return typeof a=="string"?a.split(" "):a}function n(a){var b=j[a[h]];return b||(b={},i++,a[h]=i,j[i]=b),b}function o(a,c,d){c||(c=b);if(k)return c.createElement(a);d||(d=n(c));var g;return d.cache[a]?g=d.cache[a].cloneNode():f.test(a)?g=(d.cache[a]=d.createElem(a)).cloneNode():g=d.createElem(a),g.canHaveChildren&&!e.test(a)&&!g.tagUrn?d.frag.appendChild(g):g}function p(a,c){a||(a=b);if(k)return a.createDocumentFragment();c=c||n(a);var d=c.frag.cloneNode(),e=0,f=m(),g=f.length;for(;e<g;e++)d.createElement(f[e]);return d}function q(a,b){b.cache||(b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag()),a.createElement=function(c){return s.shivMethods?o(c,a,b):b.createElem(c)},a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+m().join().replace(/[\w\-]+/g,function(a){return b.createElem(a),b.frag.createElement(a),'c("'+a+'")'})+");return n}")(s,b.frag)}function r(a){a||(a=b);var c=n(a);return s.shivCSS&&!g&&!c.hasCSS&&(c.hasCSS=!!l(a,"article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}")),k||q(a,c),a}var c="3.7.0",d=a.html5||{},e=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,f=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,g,h="_html5shiv",i=0,j={},k;(function(){try{var a=b.createElement("a");a.innerHTML="<xyz></xyz>",g="hidden"in a,k=a.childNodes.length==1||function(){b.createElement("a");var a=b.createDocumentFragment();return typeof a.cloneNode=="undefined"||typeof a.createDocumentFragment=="undefined"||typeof a.createElement=="undefined"}()}catch(c){g=!0,k=!0}})();var s={elements:d.elements||"abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output progress section summary template time video",version:c,shivCSS:d.shivCSS!==!1,supportsUnknownElements:k,shivMethods:d.shivMethods!==!1,type:"default",shivDocument:r,createElement:o,createDocumentFragment:p};a.html5=s,r(b)}(this,b),e._version=d,e._domPrefixes=o,e._cssomPrefixes=n,e.testProp=function(a){return B([a])},e.testAllProps=D,e.prefixed=function(a,b,c){return b?D(a,b,c):D(a,"pfx")},g.className=g.className.replace(/(^|\s)no-js(\s|$)/,"$1$2")+(f?" js "+s.join(" "):""),e}(this,this.document),function(a,b,c){function d(a){return"[object Function]"==o.call(a)}function e(a){return"string"==typeof a}function f(){}function g(a){return!a||"loaded"==a||"complete"==a||"uninitialized"==a}function h(){var a=p.shift();q=1,a?a.t?m(function(){("c"==a.t?B.injectCss:B.injectJs)(a.s,0,a.a,a.x,a.e,1)},0):(a(),h()):q=0}function i(a,c,d,e,f,i,j){function k(b){if(!o&&g(l.readyState)&&(u.r=o=1,!q&&h(),l.onload=l.onreadystatechange=null,b)){"img"!=a&&m(function(){t.removeChild(l)},50);for(var d in y[c])y[c].hasOwnProperty(d)&&y[c][d].onload()}}var j=j||B.errorTimeout,l=b.createElement(a),o=0,r=0,u={t:d,s:c,e:f,a:i,x:j};1===y[c]&&(r=1,y[c]=[]),"object"==a?l.data=c:(l.src=c,l.type=a),l.width=l.height="0",l.onerror=l.onload=l.onreadystatechange=function(){k.call(this,r)},p.splice(e,0,u),"img"!=a&&(r||2===y[c]?(t.insertBefore(l,s?null:n),m(k,j)):y[c].push(l))}function j(a,b,c,d,f){return q=0,b=b||"j",e(a)?i("c"==b?v:u,a,b,this.i++,c,d,f):(p.splice(this.i++,0,a),1==p.length&&h()),this}function k(){var a=B;return a.loader={load:j,i:0},a}var l=b.documentElement,m=a.setTimeout,n=b.getElementsByTagName("script")[0],o={}.toString,p=[],q=0,r="MozAppearance"in l.style,s=r&&!!b.createRange().compareNode,t=s?l:n.parentNode,l=a.opera&&"[object Opera]"==o.call(a.opera),l=!!b.attachEvent&&!l,u=r?"object":l?"script":"img",v=l?"script":u,w=Array.isArray||function(a){return"[object Array]"==o.call(a)},x=[],y={},z={timeout:function(a,b){return b.length&&(a.timeout=b[0]),a}},A,B;B=function(a){function b(a){var a=a.split("!"),b=x.length,c=a.pop(),d=a.length,c={url:c,origUrl:c,prefixes:a},e,f,g;for(f=0;f<d;f++)g=a[f].split("="),(e=z[g.shift()])&&(c=e(c,g));for(f=0;f<b;f++)c=x[f](c);return c}function g(a,e,f,g,h){var i=b(a),j=i.autoCallback;i.url.split(".").pop().split("?").shift(),i.bypass||(e&&(e=d(e)?e:e[a]||e[g]||e[a.split("/").pop().split("?")[0]]),i.instead?i.instead(a,e,f,g,h):(y[i.url]?i.noexec=!0:y[i.url]=1,f.load(i.url,i.forceCSS||!i.forceJS&&"css"==i.url.split(".").pop().split("?").shift()?"c":c,i.noexec,i.attrs,i.timeout),(d(e)||d(j))&&f.load(function(){k(),e&&e(i.origUrl,h,g),j&&j(i.origUrl,h,g),y[i.url]=2})))}function h(a,b){function c(a,c){if(a){if(e(a))c||(j=function(){var a=[].slice.call(arguments);k.apply(this,a),l()}),g(a,j,b,0,h);else if(Object(a)===a)for(n in m=function(){var b=0,c;for(c in a)a.hasOwnProperty(c)&&b++;return b}(),a)a.hasOwnProperty(n)&&(!c&&!--m&&(d(j)?j=function(){var a=[].slice.call(arguments);k.apply(this,a),l()}:j[n]=function(a){return function(){var b=[].slice.call(arguments);a&&a.apply(this,b),l()}}(k[n])),g(a[n],j,b,n,h))}else!c&&l()}var h=!!a.test,i=a.load||a.both,j=a.callback||f,k=j,l=a.complete||f,m,n;c(h?a.yep:a.nope,!!i),i&&c(i)}var i,j,l=this.yepnope.loader;if(e(a))g(a,0,l,0);else if(w(a))for(i=0;i<a.length;i++)j=a[i],e(j)?g(j,0,l,0):w(j)?B(j):Object(j)===j&&h(j,l);else Object(a)===a&&h(a,l)},B.addPrefix=function(a,b){z[a]=b},B.addFilter=function(a){x.push(a)},B.errorTimeout=1e4,null==b.readyState&&b.addEventListener&&(b.readyState="loading",b.addEventListener("DOMContentLoaded",A=function(){b.removeEventListener("DOMContentLoaded",A,0),b.readyState="complete"},0)),a.yepnope=k(),a.yepnope.executeStack=h,a.yepnope.injectJs=function(a,c,d,e,i,j){var k=b.createElement("script"),l,o,e=e||B.errorTimeout;k.src=a;for(o in d)k.setAttribute(o,d[o]);c=j?h:c||f,k.onreadystatechange=k.onload=function(){!l&&g(k.readyState)&&(l=1,c(),k.onload=k.onreadystatechange=null)},m(function(){l||(l=1,c(1))},e),i?k.onload():n.parentNode.insertBefore(k,n)},a.yepnope.injectCss=function(a,c,d,e,g,i){var e=b.createElement("link"),j,c=i?h:c||f;e.href=a,e.rel="stylesheet",e.type="text/css";for(j in d)e.setAttribute(j,d[j]);g||(n.parentNode.insertBefore(e,n),m(c,0))}}(this,document),Modernizr.load=function(){yepnope.apply(window,[].slice.call(arguments,0))};
  </script>

 <script>
  ( function( window ) {

'use strict';


function classReg( className ) {
  return new RegExp("(^|\\s+)" + className + "(\\s+|$)");
}

var hasClass, addClass, removeClass;

if ( 'classList' in document.documentElement ) {
  hasClass = function( elem, c ) {
    return elem.classList.contains( c );
  };
  addClass = function( elem, c ) {
    elem.classList.add( c );
  };
  removeClass = function( elem, c ) {
    elem.classList.remove( c );
  };
}
else {
  hasClass = function( elem, c ) {
    return classReg( c ).test( elem.className );
  };
  addClass = function( elem, c ) {
    if ( !hasClass( elem, c ) ) {
      elem.className = elem.className + ' ' + c;
    }
  };
  removeClass = function( elem, c ) {
    elem.className = elem.className.replace( classReg( c ), ' ' );
  };
}

function toggleClass( elem, c ) {
  var fn = hasClass( elem, c ) ? removeClass : addClass;
  fn( elem, c );
}

var classie = {
  // full names
  hasClass: hasClass,
  addClass: addClass,
  removeClass: removeClass,
  toggleClass: toggleClass,
  // short names
  has: hasClass,
  add: addClass,
  remove: removeClass,
  toggle: toggleClass
};

// transport
if ( typeof define === 'function' && define.amd ) {
  // AMD
  define( classie );
} else {
  // browser global
  window.classie = classie;
}

})( window );
</script>
  <script>
  ;( function( window ) {

 'use strict';

 var transEndEventNames = {
   'WebkitTransition': 'webkitTransitionEnd',
   'MozTransition': 'transitionend',
   'OTransition': 'oTransitionEnd',
   'msTransition': 'MSTransitionEnd',
   'transition': 'transitionend'
  },
  transEndEventName = transEndEventNames[ Modernizr.prefixed( 'transition' ) ],
  support = { transitions : Modernizr.csstransitions };

 function extend( a, b ) {
  for( var key in b ) {
   if( b.hasOwnProperty( key ) ) {
    a[key] = b[key];
   }
  }
  return a;
 }

 function SVGEl( el ) {
  this.el = el;
  this.paths = [].slice.call( this.el.querySelectorAll( 'path' ) );
  this.pathsArr = new Array();
  this.lengthsArr = new Array();
  this._init();
 }

 SVGEl.prototype._init = function() {
  var self = this;
  this.paths.forEach( function( path, i ) {
   self.pathsArr[i] = path;
   path.style.strokeDasharray = self.lengthsArr[i] = path.getTotalLength();
  } );
  this.draw(0);
 }

 SVGEl.prototype.draw = function( val ) {
  for( var i = 0, len = this.pathsArr.length; i < len; ++i ){
   this.pathsArr[ i ].style.strokeDashoffset = this.lengthsArr[ i ] * ( 1 - val );
  }
 }

 function UIProgressButton( el, options ) {
  this.el = el;
  this.options = extend( {}, this.options );
  extend( this.options, options );
  this._init();
 }

 UIProgressButton.prototype.options = {
  statusTime : 1500
 }

 UIProgressButton.prototype._init = function() {
  // the button
  this.button = this.el.querySelector( 'button' );
  // progress el
  this.progressEl = new SVGEl( this.el.querySelector( 'svg.progress-circle' ) );
  // the success/error elems
  this.successEl = new SVGEl( this.el.querySelector( 'svg.checkmark' ) );
  this.errorEl = new SVGEl( this.el.querySelector( 'svg.cross' ) );
  // init events
  this._initEvents();
  // enable button
  this._enable();
 }

 UIProgressButton.prototype._initEvents = function() {
  var self = this;
  this.button.addEventListener( 'click', function() { self._submit(); } );
 }

 UIProgressButton.prototype._submit = function() {
  // by adding the loading class the button will transition to a "circle"
  classie.addClass( this.el, 'loading' );
 
  var self = this,
   onEndBtnTransitionFn = function( ev ) {
    if( support.transitions ) {
     if( ev.propertyName !== 'width' ) return false;
     this.removeEventListener( transEndEventName, onEndBtnTransitionFn );
    }
   
    // disable the button - this should have been the first thing to do when clicking the button.
    // however if we do so Firefox does not seem to fire the transitionend event.
    this.setAttribute( 'disabled', '' );

    if( typeof self.options.callback === 'function' ) {
     self.options.callback( self );
    }
    else {
     // fill it (time will be the one defined in the CSS transition-duration property)
     self.setProgress(1);
     self.stop();
    }
   };

  if( support.transitions ) {
   this.button.addEventListener( transEndEventName, onEndBtnTransitionFn );
  }
  else {
   onEndBtnTransitionFn();
  }
 }

 // runs after the progress reaches 100%
 UIProgressButton.prototype.stop = function( status ) {
  var self = this,
   endLoading = function() {
    // first undraw progress stroke.
    self.progressEl.draw(0);
   
    if( typeof status === 'number' ) {
     var statusClass = status >= 0 ? 'success' : 'error',
      statusEl = status >=0 ? self.successEl : self.errorEl;

     // draw stroke of success (checkmark) or error (cross).
     statusEl.draw( 1 );
     // add respective class to the element
     classie.addClass( self.el, statusClass );
     // after options.statusTime remove status and undraw the respective stroke. Also enable the button.
     setTimeout( function() {
      classie.remove( self.el, statusClass );
      statusEl.draw(0);
      self._enable();
     }, self.options.statusTime );
    }
    else {
     self._enable();
    }
    // finally remove class loading.
    classie.removeClass( self.el, 'loading' );
   };

  // give it a time (ideally the same like the transition time) so that the last progress increment animation is still visible.
  setTimeout( endLoading, 300 );
 }

 UIProgressButton.prototype.setProgress = function( val ) {
  this.progressEl.draw( val );
 }

 // enable button
 UIProgressButton.prototype._enable = function() {
  this.button.removeAttribute( 'disabled' );
 }

 // add to global namespace
 window.UIProgressButton = UIProgressButton;

})( window );
  </script>
  <script>
   [].slice.call( document.querySelectorAll( '.progress-button' ) ).forEach( function( bttn, pos ) {
    new UIProgressButton( bttn, {
     callback : function( instance ) {
      var progress = 0,
       interval = setInterval( function() {
        progress = Math.min( progress + Math.random() * 0.1, 1 );
        instance.setProgress( progress );

        if( progress === 1 ) {
         instance.stop( pos === 1 || pos === 3 ? -1 : 1 );
         clearInterval( interval );
        }
       }, 150 );
     }
    } );
   } );
  </script>
Step 8: Click the Layout and Add a Gadget then
Step 9:
Click the HTML/JavaScript then

Step 10: Copy the Below code And Paste on it.

<div class="container">
<section>
    <h2>Default progress button (success and error)</h2>
    <div class="box">
     <!-- progress button -->
     <div class="progress-button">
      <button><span>Submit</span></button>
      <svg class="progress-circle" width="70" height="70"><path d="m35,2.5c17.955803,0 32.5,14.544199 32.5,32.5c0,17.955803 -14.544197,32.5 -32.5,32.5c-17.955803,0 -32.5,-14.544197 -32.5,-32.5c0,-17.955801 14.544197,-32.5 32.5,-32.5z"/></svg>
      <svg class="checkmark" width="70" height="70"><path d="m31.5,46.5l15.3,-23.2"/><path d="m31.5,46.5l-8.5,-7.1"/></svg>
      <svg class="cross" width="70" height="70"><path d="m35,35l-9.3,-9.3"/><path d="m35,35l9.3,9.3"/><path d="m35,35l-9.3,9.3"/><path d="m35,35l9.3,-9.3"/></svg>
     </div><!-- /progress-button -->
     <!-- progress button -->
     <div class="progress-button">
      <button><span>Submit</span></button>
      <svg class="progress-circle" width="70" height="70"><path d="m35,2.5c17.955803,0 32.5,14.544199 32.5,32.5c0,17.955803 -14.544197,32.5 -32.5,32.5c-17.955803,0 -32.5,-14.544197 -32.5,-32.5c0,-17.955801 14.544197,-32.5 32.5,-32.5z"/></svg>
      <svg class="checkmark" width="70" height="70"><path d="m31.5,46.5l15.3,-23.2"/><path d="m31.5,46.5l-8.5,-7.1"/></svg>
      <svg class="cross" width="70" height="70"><path d="m35,35l-9.3,-9.3"/><path d="m35,35l9.3,9.3"/><path d="m35,35l-9.3,9.3"/><path d="m35,35l9.3,-9.3"/></svg>
     </div><!-- /progress-button -->
    </div>
    <h2>Elastic version, with some easings (success, error)</h2>
    <div class="box">
     <!-- progress button -->
     <div class="progress-button elastic">
      <button><span>Submit</span></button>
      <svg class="progress-circle" width="70" height="70"><path d="m35,2.5c17.955803,0 32.5,14.544199 32.5,32.5c0,17.955803 -14.544197,32.5 -32.5,32.5c-17.955803,0 -32.5,-14.544197 -32.5,-32.5c0,-17.955801 14.544197,-32.5 32.5,-32.5z"/></svg>
      <svg class="checkmark" width="70" height="70"><path d="m31.5,46.5l15.3,-23.2"/><path d="m31.5,46.5l-8.5,-7.1"/></svg>
      <svg class="cross" width="70" height="70"><path d="m35,35l-9.3,-9.3"/><path d="m35,35l9.3,9.3"/><path d="m35,35l-9.3,9.3"/><path d="m35,35l9.3,-9.3"/></svg>
     </div><!-- /progress-button -->
     <!-- progress button -->
     <div class="progress-button elastic">
      <button><span>Submit</span></button>
      <svg class="progress-circle" width="70" height="70"><path d="m35,2.5c17.955803,0 32.5,14.544199 32.5,32.5c0,17.955803 -14.544197,32.5 -32.5,32.5c-17.955803,0 -32.5,-14.544197 -32.5,-32.5c0,-17.955801 14.544197,-32.5 32.5,-32.5z"/></svg>
      <svg class="checkmark" width="70" height="70"><path d="m31.5,46.5l15.3,-23.2"/><path d="m31.5,46.5l-8.5,-7.1"/></svg>
      <svg class="cross" width="70" height="70"><path d="m35,35l-9.3,-9.3"/><path d="m35,35l9.3,9.3"/><path d="m35,35l-9.3,9.3"/><path d="m35,35l9.3,-9.3"/></svg>
     </div><!-- /progress-button -->
    </div>
   </section>
  </div>
Step 11: Save it and It will works. 
     
Circular Animated Button
18.9 KB
Circular Animated Button
View a Sample
  • Blogger Comments
  • Facebook Comments

0 comments:

Post a Comment

Item Reviewed: Circular Animated Button Description: Rating: 5 Reviewed By: Unknown
Scroll to Top