You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
11 lines
14 KiB
11 lines
14 KiB
/*!
|
|
* # Semantic UI 2.0.0 - Visibility
|
|
* http://github.com/semantic-org/semantic-ui/
|
|
*
|
|
*
|
|
* Copyright 2015 Contributors
|
|
* Released under the MIT license
|
|
* http://opensource.org/licenses/MIT
|
|
*
|
|
*/
|
|
!function(e,o,n,t){"use strict";e.fn.visibility=function(i){var s,c=e(this),r=c.selector||"",a=(new Date).getTime(),l=[],d=arguments[0],u="string"==typeof d,f=[].slice.call(arguments,1);return c.each(function(){var c,m,b,g=e.isPlainObject(i)?e.extend(!0,{},e.fn.visibility.settings,i):e.extend({},e.fn.visibility.settings),p=g.className,v=g.namespace,h=g.error,P=g.metadata,x="."+v,C="module-"+v,y=e(o),V=e(this),S=e(g.context),R=(V.selector||"",V.data(C)),k=o.requestAnimationFrame||o.mozRequestAnimationFrame||o.webkitRequestAnimationFrame||o.msRequestAnimationFrame||function(e){setTimeout(e,0)},T=this;b={initialize:function(){b.debug("Initializing",g),b.setup.cache(),b.should.trackChanges()&&("image"==g.type&&b.setup.image(),"fixed"==g.type&&b.setup.fixed(),g.observeChanges&&b.observeChanges(),b.bind.events()),b.save.position(),b.is.visible()||b.error(h.visible,V),g.initialCheck&&b.checkVisibility(),b.instantiate()},instantiate:function(){b.debug("Storing instance",b),V.data(C,b),R=b},destroy:function(){b.verbose("Destroying previous module"),m&&m.disconnect(),y.off("load"+x,b.event.load).off("resize"+x,b.event.resize),S.off("scrollchange"+x,b.event.scrollchange),V.off(x).removeData(C)},observeChanges:function(){S[0];"MutationObserver"in o&&(m=new MutationObserver(function(e){b.verbose("DOM tree modified, updating visibility calculations"),b.timer=setTimeout(function(){b.verbose("DOM tree modified, updating sticky menu"),b.refresh()},100)}),m.observe(T,{childList:!0,subtree:!0}),b.debug("Setting up mutation observer",m))},bind:{events:function(){b.verbose("Binding visibility events to scroll and resize"),g.refreshOnLoad&&y.on("load"+x,b.event.load),y.on("resize"+x,b.event.resize),S.off("scroll"+x).on("scroll"+x,b.event.scroll).on("scrollchange"+x,b.event.scrollchange)}},event:{resize:function(){b.debug("Window resized"),k(b.refresh)},load:function(){b.debug("Page finished loading"),k(b.refresh)},scroll:function(){g.throttle?(clearTimeout(b.timer),b.timer=setTimeout(function(){S.triggerHandler("scrollchange"+x,[S.scrollTop()])},g.throttle)):k(function(){S.triggerHandler("scrollchange"+x,[S.scrollTop()])})},scrollchange:function(e,o){b.checkVisibility(o)}},precache:function(o,t){o instanceof Array||(o=[o]);for(var i=o.length,s=0,c=[],r=n.createElement("img"),a=function(){s++,s>=o.length&&e.isFunction(t)&&t()};i--;)r=n.createElement("img"),r.onload=a,r.onerror=a,r.src=o[i],c.push(r)},should:{trackChanges:function(){return u?(b.debug("One time query, no need to bind events"),!1):(b.debug("Callbacks being attached"),!0)}},setup:{cache:function(){b.cache={occurred:{},screen:{},element:{}}},image:function(){var e=V.data(P.src);e&&(b.verbose("Lazy loading image",e),g.once=!0,g.observeChanges=!1,g.onTopVisible=function(){b.debug("Image top visible",T),b.precache(e,function(){b.set.image(e)})})},fixed:function(){b.debug("Setting up fixed"),g.once=!1,g.observeChanges=!1,g.initialCheck=!0,g.refreshOnLoad=!0,i.transition||(g.transition=!1),b.create.placeholder(),b.debug("Added placeholder",c),g.onTopPassed=function(){b.debug("Element passed, adding fixed position",V),b.show.placeholder(),b.set.fixed(),g.transition&&e.fn.transition!==t&&V.transition(g.transition,g.duration)},g.onTopPassedReverse=function(){b.debug("Element returned to position, removing fixed",V),b.hide.placeholder(),b.remove.fixed()}}},create:{placeholder:function(){b.verbose("Creating fixed position placeholder"),c=V.clone(!1).css("display","none").addClass(p.placeholder).insertAfter(V)}},show:{placeholder:function(){b.verbose("Showing placeholder"),c.css("display","block").css("visibility","hidden")}},hide:{placeholder:function(){b.verbose("Hiding placeholder"),c.css("display","none").css("visibility","")}},set:{fixed:function(){b.verbose("Setting element to fixed position"),V.addClass(p.fixed).css({position:"fixed",top:g.offset+"px",left:"auto",zIndex:"1"})},image:function(o){V.attr("src",o),g.transition?e.fn.transition!==t?V.transition(g.transition,g.duration):V.fadeIn(g.duration):V.show()}},is:{onScreen:function(){var e=b.get.elementCalculations();return e.onScreen},offScreen:function(){var e=b.get.elementCalculations();return e.offScreen},visible:function(){return b.cache&&b.cache.element?!(0===b.cache.element.width&&0===b.cache.element.offset.top):!1}},refresh:function(){b.debug("Refreshing constants (width/height)"),"fixed"==g.type&&(b.remove.fixed(),b.remove.occurred()),b.reset(),b.save.position(),b.checkVisibility(),g.onRefresh.call(T)},reset:function(){b.verbose("Reseting all cached values"),e.isPlainObject(b.cache)&&(b.cache.screen={},b.cache.element={})},checkVisibility:function(e){b.verbose("Checking visibility of element",b.cache.element),b.is.visible()&&(b.save.scroll(e),b.save.calculations(),b.passed(),b.passingReverse(),b.topVisibleReverse(),b.bottomVisibleReverse(),b.topPassedReverse(),b.bottomPassedReverse(),b.onScreen(),b.offScreen(),b.passing(),b.topVisible(),b.bottomVisible(),b.topPassed(),b.bottomPassed(),g.onUpdate&&g.onUpdate.call(T,b.get.elementCalculations()))},passed:function(o,n){var i=b.get.elementCalculations();if(o&&n)g.onPassed[o]=n;else{if(o!==t)return b.get.pixelsPassed(o)>i.pixelsPassed;i.passing&&e.each(g.onPassed,function(e,o){i.bottomVisible||i.pixelsPassed>b.get.pixelsPassed(e)?b.execute(o,e):g.once||b.remove.occurred(o)})}},onScreen:function(e){var o=b.get.elementCalculations(),n=e||g.onOnScreen,i="onScreen";return e&&(b.debug("Adding callback for onScreen",e),g.onOnScreen=e),o.onScreen?b.execute(n,i):g.once||b.remove.occurred(i),e!==t?o.onOnScreen:void 0},offScreen:function(e){var o=b.get.elementCalculations(),n=e||g.onOffScreen,i="offScreen";return e&&(b.debug("Adding callback for offScreen",e),g.onOffScreen=e),o.offScreen?b.execute(n,i):g.once||b.remove.occurred(i),e!==t?o.onOffScreen:void 0},passing:function(e){var o=b.get.elementCalculations(),n=e||g.onPassing,i="passing";return e&&(b.debug("Adding callback for passing",e),g.onPassing=e),o.passing?b.execute(n,i):g.once||b.remove.occurred(i),e!==t?o.passing:void 0},topVisible:function(e){var o=b.get.elementCalculations(),n=e||g.onTopVisible,i="topVisible";return e&&(b.debug("Adding callback for top visible",e),g.onTopVisible=e),o.topVisible?b.execute(n,i):g.once||b.remove.occurred(i),e===t?o.topVisible:void 0},bottomVisible:function(e){var o=b.get.elementCalculations(),n=e||g.onBottomVisible,i="bottomVisible";return e&&(b.debug("Adding callback for bottom visible",e),g.onBottomVisible=e),o.bottomVisible?b.execute(n,i):g.once||b.remove.occurred(i),e===t?o.bottomVisible:void 0},topPassed:function(e){var o=b.get.elementCalculations(),n=e||g.onTopPassed,i="topPassed";return e&&(b.debug("Adding callback for top passed",e),g.onTopPassed=e),o.topPassed?b.execute(n,i):g.once||b.remove.occurred(i),e===t?o.topPassed:void 0},bottomPassed:function(e){var o=b.get.elementCalculations(),n=e||g.onBottomPassed,i="bottomPassed";return e&&(b.debug("Adding callback for bottom passed",e),g.onBottomPassed=e),o.bottomPassed?b.execute(n,i):g.once||b.remove.occurred(i),e===t?o.bottomPassed:void 0},passingReverse:function(e){var o=b.get.elementCalculations(),n=e||g.onPassingReverse,i="passingReverse";return e&&(b.debug("Adding callback for passing reverse",e),g.onPassingReverse=e),o.passing?g.once||b.remove.occurred(i):b.get.occurred("passing")&&b.execute(n,i),e!==t?!o.passing:void 0},topVisibleReverse:function(e){var o=b.get.elementCalculations(),n=e||g.onTopVisibleReverse,i="topVisibleReverse";return e&&(b.debug("Adding callback for top visible reverse",e),g.onTopVisibleReverse=e),o.topVisible?g.once||b.remove.occurred(i):b.get.occurred("topVisible")&&b.execute(n,i),e===t?!o.topVisible:void 0},bottomVisibleReverse:function(e){var o=b.get.elementCalculations(),n=e||g.onBottomVisibleReverse,i="bottomVisibleReverse";return e&&(b.debug("Adding callback for bottom visible reverse",e),g.onBottomVisibleReverse=e),o.bottomVisible?g.once||b.remove.occurred(i):b.get.occurred("bottomVisible")&&b.execute(n,i),e===t?!o.bottomVisible:void 0},topPassedReverse:function(e){var o=b.get.elementCalculations(),n=e||g.onTopPassedReverse,i="topPassedReverse";return e&&(b.debug("Adding callback for top passed reverse",e),g.onTopPassedReverse=e),o.topPassed?g.once||b.remove.occurred(i):b.get.occurred("topPassed")&&b.execute(n,i),e===t?!o.onTopPassed:void 0},bottomPassedReverse:function(e){var o=b.get.elementCalculations(),n=e||g.onBottomPassedReverse,i="bottomPassedReverse";return e&&(b.debug("Adding callback for bottom passed reverse",e),g.onBottomPassedReverse=e),o.bottomPassed?g.once||b.remove.occurred(i):b.get.occurred("bottomPassed")&&b.execute(n,i),e===t?!o.bottomPassed:void 0},execute:function(e,o){var n=b.get.elementCalculations(),t=b.get.screenCalculations();e=e||!1,e&&(g.continuous?(b.debug("Callback being called continuously",o,n),e.call(T,n,t)):b.get.occurred(o)||(b.debug("Conditions met",o,n),e.call(T,n,t))),b.save.occurred(o)},remove:{fixed:function(){b.debug("Removing fixed position"),V.removeClass(p.fixed).css({position:"",top:"",left:"",zIndex:""})},occurred:function(e){if(e){var o=b.cache.occurred;o[e]!==t&&o[e]===!0&&(b.debug("Callback can now be called again",e),b.cache.occurred[e]=!1)}else b.cache.occurred={}}},save:{calculations:function(){b.verbose("Saving all calculations necessary to determine positioning"),b.save.direction(),b.save.screenCalculations(),b.save.elementCalculations()},occurred:function(e){e&&(b.cache.occurred[e]===t||b.cache.occurred[e]!==!0)&&(b.verbose("Saving callback occurred",e),b.cache.occurred[e]=!0)},scroll:function(e){e=e+g.offset||S.scrollTop()+g.offset,b.cache.scroll=e},direction:function(){var e,o=b.get.scroll(),n=b.get.lastScroll();return e=o>n&&n?"down":n>o&&n?"up":"static",b.cache.direction=e,b.cache.direction},elementPosition:function(){var e=b.cache.element,o=b.get.screenSize();return b.verbose("Saving element position"),e.fits=e.height<o.height,e.offset=V.offset(),e.width=V.outerWidth(),e.height=V.outerHeight(),b.cache.element=e,console.log(e.offset,V),e},elementCalculations:function(){var e=b.get.screenCalculations(),o=b.get.elementPosition();return g.includeMargin?(o.margin={},o.margin.top=parseInt(V.css("margin-top"),10),o.margin.bottom=parseInt(V.css("margin-bottom"),10),o.top=o.offset.top-o.margin.top,o.bottom=o.offset.top+o.height+o.margin.bottom):(o.top=o.offset.top,o.bottom=o.offset.top+o.height),o.topVisible=e.bottom>=o.top,o.topPassed=e.top>=o.top,o.bottomVisible=e.bottom>=o.bottom,o.bottomPassed=e.top>=o.bottom,o.pixelsPassed=0,o.percentagePassed=0,o.onScreen=o.topVisible&&!o.bottomPassed,o.passing=o.topPassed&&!o.bottomPassed,o.offScreen=!o.onScreen,o.passing&&(o.pixelsPassed=e.top-o.top,o.percentagePassed=(e.top-o.top)/o.height),b.cache.element=o,b.verbose("Updated element calculations",o),o},screenCalculations:function(){var e=b.get.scroll();return b.save.direction(),b.cache.screen.top=e,b.cache.screen.bottom=e+b.cache.screen.height,b.cache.screen},screenSize:function(){b.verbose("Saving window position"),b.cache.screen={height:S.height()}},position:function(){b.save.screenSize(),b.save.elementPosition()}},get:{pixelsPassed:function(e){var o=b.get.elementCalculations();return e.search("%")>-1?o.height*(parseInt(e,10)/100):parseInt(e,10)},occurred:function(e){return b.cache.occurred!==t?b.cache.occurred[e]||!1:!1},direction:function(){return b.cache.direction===t&&b.save.direction(),b.cache.direction},elementPosition:function(){return b.cache.element===t&&b.save.elementPosition(),b.cache.element},elementCalculations:function(){return b.cache.element===t&&b.save.elementCalculations(),b.cache.element},screenCalculations:function(){return b.cache.screen===t&&b.save.screenCalculations(),b.cache.screen},screenSize:function(){return b.cache.screen===t&&b.save.screenSize(),b.cache.screen},scroll:function(){return b.cache.scroll===t&&b.save.scroll(),b.cache.scroll},lastScroll:function(){return b.cache.screen===t?(b.debug("First scroll event, no last scroll could be found"),!1):b.cache.screen.top}},setting:function(o,n){if(e.isPlainObject(o))e.extend(!0,g,o);else{if(n===t)return g[o];g[o]=n}},internal:function(o,n){if(e.isPlainObject(o))e.extend(!0,b,o);else{if(n===t)return b[o];b[o]=n}},debug:function(){g.debug&&(g.performance?b.performance.log(arguments):(b.debug=Function.prototype.bind.call(console.info,console,g.name+":"),b.debug.apply(console,arguments)))},verbose:function(){g.verbose&&g.debug&&(g.performance?b.performance.log(arguments):(b.verbose=Function.prototype.bind.call(console.info,console,g.name+":"),b.verbose.apply(console,arguments)))},error:function(){b.error=Function.prototype.bind.call(console.error,console,g.name+":"),b.error.apply(console,arguments)},performance:{log:function(e){var o,n,t;g.performance&&(o=(new Date).getTime(),t=a||o,n=o-t,a=o,l.push({Name:e[0],Arguments:[].slice.call(e,1)||"",Element:T,"Execution Time":n})),clearTimeout(b.performance.timer),b.performance.timer=setTimeout(b.performance.display,500)},display:function(){var o=g.name+":",n=0;a=!1,clearTimeout(b.performance.timer),e.each(l,function(e,o){n+=o["Execution Time"]}),o+=" "+n+"ms",r&&(o+=" '"+r+"'"),(console.group!==t||console.table!==t)&&l.length>0&&(console.groupCollapsed(o),console.table?console.table(l):e.each(l,function(e,o){console.log(o.Name+": "+o["Execution Time"]+"ms")}),console.groupEnd()),l=[]}},invoke:function(o,n,i){var c,r,a,l=R;return n=n||f,i=T||i,"string"==typeof o&&l!==t&&(o=o.split(/[\. ]/),c=o.length-1,e.each(o,function(n,i){var s=n!=c?i+o[n+1].charAt(0).toUpperCase()+o[n+1].slice(1):o;if(e.isPlainObject(l[s])&&n!=c)l=l[s];else{if(l[s]!==t)return r=l[s],!1;if(!e.isPlainObject(l[i])||n==c)return l[i]!==t?(r=l[i],!1):(b.error(h.method,o),!1);l=l[i]}})),e.isFunction(r)?a=r.apply(i,n):r!==t&&(a=r),e.isArray(s)?s.push(a):s!==t?s=[s,a]:a!==t&&(s=a),r}},u?(R===t&&b.initialize(),R.save.scroll(),R.save.calculations(),b.invoke(d)):(R!==t&&R.invoke("destroy"),b.initialize())}),s!==t?s:this},e.fn.visibility.settings={name:"Visibility",namespace:"visibility",debug:!1,verbose:!1,performance:!0,observeChanges:!0,refreshOnLoad:!0,once:!0,continuous:!1,offset:0,includeMargin:!1,context:o,initialCheck:!0,throttle:!1,type:!1,transition:"fade in",duration:1e3,onPassed:{},onOnScreen:!1,onOffScreen:!1,onPassing:!1,onTopVisible:!1,onBottomVisible:!1,onTopPassed:!1,onBottomPassed:!1,onPassingReverse:!1,onTopVisibleReverse:!1,onBottomVisibleReverse:!1,onTopPassedReverse:!1,onBottomPassedReverse:!1,onUpdate:!1,onRefresh:function(){},metadata:{src:"src"},className:{fixed:"fixed",placeholder:"placeholder"},error:{method:"The method you called is not defined.",visible:"Element is hidden, you must call refresh after element becomes visible"}}}(jQuery,window,document);
|