6 Item Grid with FontAwesome Icons than animate in (possibly when displayed on screen and not straight away) and a Parallax Scrolling background.
CSS
/* ===== Main Features ===== */ #off-jsn-content-top-below, #demo-main-features { background: url(../../../media/joomlashine/jsn-mini/custom-html/bg/workplace.jpg) center center fixed; background-size: 100% auto; } #demo-main-features { padding: 30px 0; } #demo-main-features .main-features { padding: 40px 0; } #demo-main-features .main-features .grid-col_inner { padding: 0 20px; } #demo-main-features .main-features .feature-item [class*="fa fa-"] { font-size: 2.5em; } #demo-main-features .main-features .feature-item .heading { color: #fff; text-transform: uppercase; font-size: 1.2em; letter-spacing: 5px; } #demo-main-features .main-features .feature-item .desc { color: #999; }
CSS (Optional / Animation / Waypoints)
/* ===== WAYPOINT ONSCROLL ACTION ===== */ /* Waypoint by http://imakewebthings.com/jquery-waypoints/ */ /* Declare scale-fade animation */ @keyframes scale-fade { 0% { transform:scale(0.5); opacity:0; filter: alpha(opacity=0); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; } 100% { transform:scale(1); opacity:1; filter: alpha(opacity=100); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; } } @-moz-keyframes scale-fade { 0% { -moz-transform:scale(0.5); opacity:0; filter: alpha(opacity=0); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; } 100% { -moz-transform:scale(1); opacity:1; filter: alpha(opacity=100); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; } } @-webkit-keyframes scale-fade { 0% { -webkit-transform:scale(0.5); opacity:0; filter: alpha(opacity=0); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; } 100% { -webkit-transform:scale(1); opacity:1; filter: alpha(opacity=100); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; } } /* Declare translate-fade animation */ @keyframes translate-fade { 0% { transform:translate(0,50px); opacity:0; filter: alpha(opacity=0); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; } 100% { transform:translate(0,0); opacity:1; filter: alpha(opacity=100); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; } } @-moz-keyframes translate-fade { 0% { -moz-transform:translate(0,50px); opacity:0; filter: alpha(opacity=0); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; } 100% { -moz-transform:translate(0,0); opacity:1; filter: alpha(opacity=100); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; } } @-webkit-keyframes translate-fade { 0% { -webkit-transform:translate(0,50px); opacity:0; filter: alpha(opacity=0); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; } 100% { -webkit-transform:translate(0,0); opacity:1; filter: alpha(opacity=100); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; } } .appearing .project-item, .appearing .main-features .feature-item [class*="fa fa-"], .appearing .graph-item .graph-item-inner, .appearing .stat-group .counting-number { opacity:0; filter: alpha(opacity=0); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; -moz-transform: scale(0.5); -webkit-transform: scale(0.5); -ms-transform: scale(0.5); transform: scale(0.5); transition: all 0.3s ease-in-out; -moz-transition: all 0.3s ease-in-out; -webkit-transition: all 0.3s ease-in-out; } .appearing.scroll-action .project-item, .appearing.scroll-action .main-features .feature-item [class*="fa fa-"], .appearing.scroll-action .graph-item .graph-item-inner, .appearing.scroll-action .stat-group .counting-number { -webkit-animation: scale-fade 0.8s 1 cubic-bezier(0,.61,.46,1.33); -moz-animation: scale-fade 0.8s 1 cubic-bezier(0,.61,.46,1.33); animation: scale-fade 0.8s 1 cubic-bezier(0,.61,.46,1.33); opacity:1; filter: alpha(opacity=100); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; -moz-transform: scale(1); -webkit-transform: scale(1); -ms-transform: scale(1); transform: scale(1); } .appearing .apple-devices { opacity:0; filter: alpha(opacity=0); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; -moz-transform: translate(0,50px); -webkit-transform: translate(0,50px); -ms-transform: translate(0,50px); transform: translate(0,50px); transition: all 0.3s ease-in-out; -moz-transition: all 0.3s ease-in-out; -webkit-transition: all 0.3s ease-in-out; } .appearing.scroll-action .apple-devices { -webkit-animation: translate-fade 1s 1 ease-in-out; -moz-animation: translate-fade 1s 1 ease-in-out; animation: translate-fade 1s 1 ease-in-out; opacity:1; filter: alpha(opacity=100); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; -moz-transform: translate(0,0); -webkit-transform: translate(0,0); -ms-transform: translate(0,0); transform: translate(0,0); } .scroll-down { } .scroll-down.scroll-action { opacity:0; filter: alpha(opacity=0); -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; }
JS (Optional / Animation / Waypoints)
/* ==================== JSN MINI CUSTOM JS ==================== */ setTimeout(function() { (function($) { //---------------------------------------- // intiates the Waypoints codebase // This causes animations to be paused until triggered by the Waypoints code // Waypoints are configured later /* Waypoints */ (function(){var t=[].indexOf||function(t){for(var e=0,n=this.length;e<n;e++){if(e in this&&this[e]===t)return e}return-1},e=[].slice;(function(t,e){if(typeof define==="function"&&define.amd){return define("waypoints",["jquery"],function(n){return e(n,t)})}else{return e(t.jQuery,t)}})(window,function(n,r){var i,o,l,s,f,u,c,a,h,d,p,y,v,w,g,m;i=n(r);a=t.call(r,"ontouchstart")>=0;s={horizontal:{},vertical:{}};f=1;c={};u="waypoints-context-id";p="resize.waypoints";y="scroll.waypoints";v=1;w="waypoints-waypoint-ids";g="waypoint";m="waypoints";o=function(){function t(t){var e=this;this.$element=t;this.element=t[0];this.didResize=false;this.didScroll=false;this.id="context"+f++;this.oldScroll={x:t.scrollLeft(),y:t.scrollTop()};this.waypoints={horizontal:{},vertical:{}};this.element[u]=this.id;c[this.id]=this;t.bind(y,function(){var t;if(!(e.didScroll||a)){e.didScroll=true;t=function(){e.doScroll();return e.didScroll=false};return r.setTimeout(t,n[m].settings.scrollThrottle)}});t.bind(p,function(){var t;if(!e.didResize){e.didResize=true;t=function(){n[m]("refresh");return e.didResize=false};return r.setTimeout(t,n[m].settings.resizeThrottle)}})}t.prototype.doScroll=function(){var t,e=this;t={horizontal:{newScroll:this.$element.scrollLeft(),oldScroll:this.oldScroll.x,forward:"right",backward:"left"},vertical:{newScroll:this.$element.scrollTop(),oldScroll:this.oldScroll.y,forward:"down",backward:"up"}};if(a&&(!t.vertical.oldScroll||!t.vertical.newScroll)){n[m]("refresh")}n.each(t,function(t,r){var i,o,l;l=[];o=r.newScroll>r.oldScroll;i=o?r.forward:r.backward;n.each(e.waypoints[t],function(t,e){var n,i;if(r.oldScroll<(n=e.offset)&&n<=r.newScroll){return l.push(e)}else if(r.newScroll<(i=e.offset)&&i<=r.oldScroll){return l.push(e)}});l.sort(function(t,e){return t.offset-e.offset});if(!o){l.reverse()}return n.each(l,function(t,e){if(e.options.continuous||t===l.length-1){return e.trigger([i])}})});return this.oldScroll={x:t.horizontal.newScroll,y:t.vertical.newScroll}};t.prototype.refresh=function(){var t,e,r,i=this;r=n.isWindow(this.element);e=this.$element.offset();this.doScroll();t={horizontal:{contextOffset:r?0:e.left,contextScroll:r?0:this.oldScroll.x,contextDimension:this.$element.width(),oldScroll:this.oldScroll.x,forward:"right",backward:"left",offsetProp:"left"},vertical:{contextOffset:r?0:e.top,contextScroll:r?0:this.oldScroll.y,contextDimension:r?n[m]("viewportHeight"):this.$element.height(),oldScroll:this.oldScroll.y,forward:"down",backward:"up",offsetProp:"top"}};return n.each(t,function(t,e){return n.each(i.waypoints[t],function(t,r){var i,o,l,s,f;i=r.options.offset;l=r.offset;o=n.isWindow(r.element)?0:r.$element.offset()[e.offsetProp];if(n.isFunction(i)){i=i.apply(r.element)}else if(typeof i==="string"){i=parseFloat(i);if(r.options.offset.indexOf("%")>-1){i=Math.ceil(e.contextDimension*i/100)}}r.offset=o-e.contextOffset+e.contextScroll-i;if(r.options.onlyOnScroll&&l!=null||!r.enabled){return}if(l!==null&&l<(s=e.oldScroll)&&s<=r.offset){return r.trigger([e.backward])}else if(l!==null&&l>(f=e.oldScroll)&&f>=r.offset){return r.trigger([e.forward])}else if(l===null&&e.oldScroll>=r.offset){return r.trigger([e.forward])}})})};t.prototype.checkEmpty=function(){if(n.isEmptyObject(this.waypoints.horizontal)&&n.isEmptyObject(this.waypoints.vertical)){this.$element.unbind([p,y].join(" "));return delete c[this.id]}};return t}();l=function(){function t(t,e,r){var i,o;if(r.offset==="bottom-in-view"){r.offset=function(){var t;t=n[m]("viewportHeight");if(!n.isWindow(e.element)){t=e.$element.height()}return t-n(this).outerHeight()}}this.$element=t;this.element=t[0];this.axis=r.horizontal?"horizontal":"vertical";this.callback=r.handler;this.context=e;this.enabled=r.enabled;this.id="waypoints"+v++;this.offset=null;this.options=r;e.waypoints[this.axis][this.id]=this;s[this.axis][this.id]=this;i=(o=this.element[w])!=null?o:[];i.push(this.id);this.element[w]=i}t.prototype.trigger=function(t){if(!this.enabled){return}if(this.callback!=null){this.callback.apply(this.element,t)}if(this.options.triggerOnce){return this.destroy()}};t.prototype.disable=function(){return this.enabled=false};t.prototype.enable=function(){this.context.refresh();return this.enabled=true};t.prototype.destroy=function(){delete s[this.axis][this.id];delete this.context.waypoints[this.axis][this.id];return this.context.checkEmpty()};t.getWaypointsByElement=function(t){var e,r;r=t[w];if(!r){return[]}e=n.extend({},s.horizontal,s.vertical);return n.map(r,function(t){return e[t]})};return t}();d={init:function(t,e){var r;e=n.extend({},n.fn[g].defaults,e);if((r=e.handler)==null){e.handler=t}this.each(function(){var t,r,i,s;t=n(this);i=(s=e.context)!=null?s:n.fn[g].defaults.context;if(!n.isWindow(i)){i=t.closest(i)}i=n(i);r=c[i[0][u]];if(!r){r=new o(i)}return new l(t,r,e)});n[m]("refresh");return this},disable:function(){return d._invoke.call(this,"disable")},enable:function(){return d._invoke.call(this,"enable")},destroy:function(){return d._invoke.call(this,"destroy")},prev:function(t,e){return d._traverse.call(this,t,e,function(t,e,n){if(e>0){return t.push(n[e-1])}})},next:function(t,e){return d._traverse.call(this,t,e,function(t,e,n){if(e<n.length-1){return t.push(n[e+1])}})},_traverse:function(t,e,i){var o,l;if(t==null){t="vertical"}if(e==null){e=r}l=h.aggregate(e);o=[];this.each(function(){var e;e=n.inArray(this,l[t]);return i(o,e,l[t])});return this.pushStack(o)},_invoke:function(t){this.each(function(){var e;e=l.getWaypointsByElement(this);return n.each(e,function(e,n){n[t]();return true})});return this}};n.fn[g]=function(){var t,r;r=arguments[0],t=2<=arguments.length?e.call(arguments,1):[];if(d[r]){return d[r].apply(this,t)}else if(n.isFunction(r)){return d.init.apply(this,arguments)}else if(n.isPlainObject(r)){return d.init.apply(this,[null,r])}else if(!r){return n.error("jQuery Waypoints needs a callback function or handler option.")}else{return n.error("The "+r+" method does not exist in jQuery Waypoints.")}};n.fn[g].defaults={context:r,continuous:true,enabled:true,horizontal:false,offset:0,triggerOnce:false};h={refresh:function(){return n.each(c,function(t,e){return e.refresh()})},viewportHeight:function(){var t;return(t=r.innerHeight)!=null?t:i.height()},aggregate:function(t){var e,r,i;e=s;if(t){e=(i=c[n(t)[0][u]])!=null?i.waypoints:void 0}if(!e){return[]}r={horizontal:[],vertical:[]};n.each(r,function(t,i){n.each(e[t],function(t,e){return i.push(e)});i.sort(function(t,e){return t.offset-e.offset});r[t]=n.map(i,function(t){return t.element});return r[t]=n.unique(r[t])});return r},above:function(t){if(t==null){t=r}return h._filter(t,"vertical",function(t,e){return e.offset<=t.oldScroll.y})},below:function(t){if(t==null){t=r}return h._filter(t,"vertical",function(t,e){return e.offset>t.oldScroll.y})},left:function(t){if(t==null){t=r}return h._filter(t,"horizontal",function(t,e){return e.offset<=t.oldScroll.x})},right:function(t){if(t==null){t=r}return h._filter(t,"horizontal",function(t,e){return e.offset>t.oldScroll.x})},enable:function(){return h._invoke("enable")},disable:function(){return h._invoke("disable")},destroy:function(){return h._invoke("destroy")},extendFn:function(t,e){return d[t]=e},_invoke:function(t){var e;e=n.extend({},s.vertical,s.horizontal);return n.each(e,function(e,n){n[t]();return true})},_filter:function(t,e,r){var i,o;i=c[n(t)[0][u]];if(!i){return[]}o=[];n.each(i.waypoints[e],function(t,e){if(r(i,e)){return o.push(e)}});o.sort(function(t,e){return t.offset-e.offset});return n.map(o,function(t){return t.element})}};n[m]=function(){var t,n;n=arguments[0],t=2<=arguments.length?e.call(arguments,1):[];if(h[n]){return h[n].apply(null,t)}else{return h.aggregate.call(null,n)}};n[m].settings={resizeThrottle:100,scrollThrottle:30};return i.on("load.waypoints",function(){return n[m]("refresh")})})}).call(this); //---------------------------------------- // Now the javascript has been setup this code triggers all the effects $(document).ready( function() { /* Add timeout for animation */ // 'Back to', simplicity, the 6 grid with icons starting 'modern design' setTimeout(function(){ $(".ping.title").addClass("pop"); },1000); setTimeout(function(){ $(".ping.desc").addClass("pop"); },1200); setTimeout(function(){ $(".ping.scroll-down").addClass("pop"); },4500); /* Waypoint script to add action when scroll onto objects */ /* This effect brought by http://imakewebthings.com/jquery-waypoints/ */ // This sets the Waypoint triggers // Waypoints is the easiest way to trigger a function when you scroll to an element. // this adds a scrolling action to elements but not the 'counting up' // delete the ones you dont use $( '#demo-main-features' ).waypoint(function() { $( '#demo-main-features' ).addClass( 'scroll-action' ); }, { offset: '70%' }) /* Parallax Scrolling */ // this scolls the background images behind the modules $('.demo-countingup-stats').attr('data-type', 'background'); $('.demo-countingup-stats').attr('data-speed', '3'); if ($( "#jsn-master" ).hasClass( "jsn-demo-page" )) { $('#jsn-content-top-below').attr('data-type', 'background'); $('#jsn-content-top-below').attr('data-speed', '3'); } $('div[data-type="background"]').each(function(){ var $bgobj = $(this); // assigning the object $window = $(window); $(window).scroll(function() { var yPos = -($window.scrollTop() / $bgobj.data('speed')); // Put together our final background position var coords = '50% '+ yPos + 'px'; // Move the background $bgobj.css({ backgroundPosition: coords }); }); }); }); //---------------------------------------- })(jQuery); }, 0);
HTML
<div id="demo-main-features" class="appearing"> <div class="grid-layout main-features"> <div class="grid-col"> <div class="feature-item"><a href="#"><i class="fa fa-pencil"></i></a> <h3 class="heading">Modern Design</h3> <p class="desc">Flat design – currently growing in popularity</p> </div> </div> <div class="grid-col"> <div class="feature-item"><a href="#"><i class="fa fa-book"></i></a> <h3 class="heading">Full Documentation</h3> <p class="desc">JSN Mini is equipped with a very comprehensive documentation package that will help you with template utilization.</p> </div> </div> <div class="grid-col"> <div class="feature-item"><a href="#"><i class="fa fa-bolt"></i></a> <h3 class="heading">Painless Configuration</h3> <p class="desc">You can configure the template the way you like without special technical knowledge</p> </div> </div> </div> <div class="grid-layout main-features"> <div class="grid-col"> <div class="feature-item"><a href="#"><i class="fa fa-eye"></i></a> <h3 class="heading">Responsive design</h3> <p class="desc">Special built-in design optimized for modern mobile devices such as iPhone, Android and Windows-based mobiles</p> </div> </div> <div class="grid-col"> <div class="feature-item"><a href="#"><i class="fa fa-bar-chart"></i></a> <h3 class="heading">Multi-language support</h3> <p class="desc">Currently, the template supports 14 languages for both front-end and back-end.</p> </div> </div> <div class="grid-col"> <div class="feature-item"><a href="#"><i class="fa fa-share-alt"></i></a> <h3 class="heading">Social media integrated</h3> <p class="desc">You are free to integrate your social channels without digging into the code</p> </div> </div> </div> </div>
Notes
- This code has been modified to use FontAwesome
- I have changed [class*="jsn-icon-"] to [class*="fa fa-"] to allow the use of FontAwesome instead of the JSN-Mini-Icon set which is not available.
- You need to add the Optional Javascript and CSS to get the animation effects.