123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- /* global NexT, CONFIG, Velocity */
- if (window.$ && window.$.Velocity) window.Velocity = window.$.Velocity;
- NexT.motion = {};
- NexT.motion.integrator = {
- queue : [],
- cursor: -1,
- init : function() {
- this.queue = [];
- this.cursor = -1;
- return this;
- },
- add: function(fn) {
- this.queue.push(fn);
- return this;
- },
- next: function() {
- this.cursor++;
- var fn = this.queue[this.cursor];
- typeof fn === 'function' && fn(NexT.motion.integrator);
- },
- bootstrap: function() {
- this.next();
- }
- };
- NexT.motion.middleWares = {
- logo: function(integrator) {
- var sequence = [];
- var brand = document.querySelector('.brand');
- var image = document.querySelector('.custom-logo-image');
- var title = document.querySelector('.site-title');
- var subtitle = document.querySelector('.site-subtitle');
- var logoLineTop = document.querySelector('.logo-line-before i');
- var logoLineBottom = document.querySelector('.logo-line-after i');
- brand && sequence.push({
- e: brand,
- p: {opacity: 1},
- o: {duration: 200}
- });
- function getMistLineSettings(element, translateX) {
- return {
- e: element,
- p: {translateX},
- o: {
- duration : 500,
- sequenceQueue: false
- }
- };
- }
- function pushImageToSequence() {
- sequence.push({
- e: image,
- p: {opacity: 1, top: 0},
- o: {duration: 200}
- });
- }
- CONFIG.scheme === 'Mist' && logoLineTop && logoLineBottom
- && sequence.push(
- getMistLineSettings(logoLineTop, '100%'),
- getMistLineSettings(logoLineBottom, '-100%')
- );
- CONFIG.scheme === 'Muse' && image && pushImageToSequence();
- title && sequence.push({
- e: title,
- p: {opacity: 1, top: 0},
- o: {duration: 200}
- });
- subtitle && sequence.push({
- e: subtitle,
- p: {opacity: 1, top: 0},
- o: {duration: 200}
- });
- (CONFIG.scheme === 'Pisces' || CONFIG.scheme === 'Gemini') && image && pushImageToSequence();
- if (sequence.length > 0) {
- sequence[sequence.length - 1].o.complete = function() {
- integrator.next();
- };
- Velocity.RunSequence(sequence);
- } else {
- integrator.next();
- }
- if (CONFIG.motion.async) {
- integrator.next();
- }
- },
- menu: function(integrator) {
- Velocity(document.querySelectorAll('.menu-item'), 'transition.slideDownIn', {
- display : null,
- duration: 200,
- complete: function() {
- integrator.next();
- }
- });
- if (CONFIG.motion.async) {
- integrator.next();
- }
- },
- subMenu: function(integrator) {
- var subMenuItem = document.querySelectorAll('.sub-menu .menu-item');
- if (subMenuItem.length > 0) {
- subMenuItem.forEach(element => {
- element.style.opacity = 1;
- });
- }
- integrator.next();
- },
- postList: function(integrator) {
- var postBlock = document.querySelectorAll('.post-block, .pagination, .comments');
- var postBlockTransition = CONFIG.motion.transition.post_block;
- var postHeader = document.querySelectorAll('.post-header');
- var postHeaderTransition = CONFIG.motion.transition.post_header;
- var postBody = document.querySelectorAll('.post-body');
- var postBodyTransition = CONFIG.motion.transition.post_body;
- var collHeader = document.querySelectorAll('.collection-header');
- var collHeaderTransition = CONFIG.motion.transition.coll_header;
- if (postBlock.length > 0) {
- var postMotionOptions = window.postMotionOptions || {
- stagger : 100,
- drag : true,
- complete: function() {
- integrator.next();
- }
- };
- if (CONFIG.motion.transition.post_block) {
- Velocity(postBlock, 'transition.' + postBlockTransition, postMotionOptions);
- }
- if (CONFIG.motion.transition.post_header) {
- Velocity(postHeader, 'transition.' + postHeaderTransition, postMotionOptions);
- }
- if (CONFIG.motion.transition.post_body) {
- Velocity(postBody, 'transition.' + postBodyTransition, postMotionOptions);
- }
- if (CONFIG.motion.transition.coll_header) {
- Velocity(collHeader, 'transition.' + collHeaderTransition, postMotionOptions);
- }
- }
- if (CONFIG.scheme === 'Pisces' || CONFIG.scheme === 'Gemini') {
- integrator.next();
- }
- },
- sidebar: function(integrator) {
- var sidebarAffix = document.querySelector('.sidebar-inner');
- var sidebarAffixTransition = CONFIG.motion.transition.sidebar;
- // Only for Pisces | Gemini.
- if (sidebarAffixTransition && (CONFIG.scheme === 'Pisces' || CONFIG.scheme === 'Gemini')) {
- Velocity(sidebarAffix, 'transition.' + sidebarAffixTransition, {
- display : null,
- duration: 200,
- complete: function() {
- // After motion complete need to remove transform from sidebar to let affix work on Pisces | Gemini.
- sidebarAffix.style.transform = 'initial';
- }
- });
- }
- integrator.next();
- }
- };
|