@progress/kendo-ui
Version:
This package is part of the [Kendo UI for jQuery](http://www.telerik.com/kendo-ui) suite.
3 lines (2 loc) • 9.99 kB
JavaScript
!function(e){"function"==typeof define&&define.amd?define(["kendo.fx.min","kendo.draganddrop.min"],e):e()}((function(){var e,i,t,n,s,l,o,a,r,c,h,d,u,m,f,p,v,b,x,y,T,_,w;e=window.kendo.jQuery,i=window.kendo,t=i.mobile,n=i.effects,s=t.ui,l=e.extend,o=s.Widget,a=i.Class,r=i.ui.Movable,c=i.ui.Pane,h=i.ui.PaneDimensions,d=n.Transition,u=n.Animation,m=Math.abs,f="km-scroller-release",p="km-scroller-refresh",v="change",b="scroll",x=u.extend({init:function(e){var i=this;u.fn.init.call(i),l(i,e),i.userEvents.bind("gestureend",i.start.bind(i)),i.tapCapture.bind("press",i.cancel.bind(i))},enabled:function(){return this.movable.scale<this.dimensions.minScale},done:function(){return this.dimensions.minScale-this.movable.scale<.01},tick:function(){var e=this.movable;e.scaleWith(1.1),this.dimensions.rescale(e.scale)},onEnd:function(){var e=this.movable;e.scaleTo(this.dimensions.minScale),this.dimensions.rescale(e.scale)}}),y=u.extend({init:function(e){var i=this;u.fn.init.call(i),l(i,e,{transition:new d({axis:e.axis,movable:e.movable,onEnd:function(){i._end()}})}),i.tapCapture.bind("press",(function(){i.cancel()})),i.userEvents.bind("end",i.start.bind(i)),i.userEvents.bind("gestureend",i.start.bind(i)),i.userEvents.bind("tap",i.onEnd.bind(i))},onCancel:function(){this.transition.cancel()},freeze:function(e){this.cancel(),this._moveTo(e)},onEnd:function(){var e=this;e.paneAxis.outOfBounds()?e._snapBack():e._end()},done:function(){return m(this.velocity)<1},start:function(e){var i,t=this;t.dimension.enabled&&(t.paneAxis.outOfBounds()?t.transition._started?(t.transition.cancel(),t.velocity=Math.min(e.touch[t.axis].velocity*t.velocityMultiplier,55),u.fn.start.call(t)):t._snapBack():(i=2===e.touch.id?0:e.touch[t.axis].velocity,t.velocity=Math.max(Math.min(i*t.velocityMultiplier,55),-55),t.tapCapture.captureNext(),u.fn.start.call(t)))},tick:function(){var e=this,i=e.dimension,t=e.paneAxis.outOfBounds()?.5:e.friction,n=e.velocity*=t,s=e.movable[e.axis]+n;!e.elastic&&i.outOfBounds(s)&&(s=Math.max(Math.min(s,i.max),i.min),e.velocity=0),e.movable.moveAxis(e.axis,s)},_end:function(){this.tapCapture.cancelCapture(),this.end()},_snapBack:function(){var e=this,i=e.dimension,t=e.movable[e.axis]>i.max?i.max:i.min;e._moveTo(t)},_moveTo:function(e){this.transition.moveTo({location:e,duration:500,ease:d.easeOutExpo})}}),T=u.extend({init:function(e){i.effects.Animation.fn.init.call(this),l(this,e,{origin:{},destination:{},offset:{}})},tick:function(){this._updateCoordinates(),this.moveTo(this.origin)},done:function(){return m(this.offset.y)<5&&m(this.offset.x)<5},onEnd:function(){this.moveTo(this.destination),this.callback&&this.callback.call()},setCoordinates:function(e,i){this.offset={},this.origin=e,this.destination=i},setCallback:function(e){e&&i.isFunction(e)?this.callback=e:e=void 0},_updateCoordinates:function(){this.offset={x:(this.destination.x-this.origin.x)/4,y:(this.destination.y-this.origin.y)/4},this.origin={y:this.origin.y+this.offset.y,x:this.origin.x+this.offset.x}}}),_=a.extend({init:function(i){var t=this,n="x"===i.axis,s=e('<div role="scrollbar" aria-controls="'+i.controlsId+'" class="km-touch-scrollbar km-'+(n?"horizontal":"vertical")+'-scrollbar" />');n&&s.attr("aria-orientation","horizontal"),l(t,i,{element:s,elementSize:0,movable:new r(s),scrollMovable:i.movable,alwaysVisible:i.alwaysVisible,size:n?"width":"height"}),t.scrollMovable.bind(v,t.refresh.bind(t)),t.container.append(s),i.alwaysVisible&&t.show()},refresh:function(){var e=this,i=e.axis,t=e.dimension,n=t.size,s=e.scrollMovable,l=n/t.total,o=Math.round(-s[i]*l),a=Math.round(n*l);l>=1?this.element.css("display","none"):this.element.css("display",""),o+a>n?a=n-o:o<0&&(a+=o,o=0),e.elementSize!=a&&(e.element.css(e.size,a+"px"),e.elementSize=a),e._ariaValue(o,t.size-e.elementSize),e.movable.moveAxis(i,o)},show:function(){this.element.css({opacity:.7,visibility:"visible"})},hide:function(){this.alwaysVisible||this.element.css({opacity:0})},_ariaValue:function(e,i){var t=this.element;e>i&&(e=i),t.attr("aria-valuemax",i),t.attr("aria-valuenow",e)}}),w=o.extend({init:function(t,n){var s=this;if(o.fn.init.call(s,t,n),t=s.element,s._native=s.options.useNative&&i.support.hasNativeScrolling,s._native)return t.addClass("km-native-scroller").prepend('<div class="km-scroll-header"/>'),void l(s,{scrollElement:t,fixedContainer:t.children().first()});t.css("overflow","hidden").addClass("km-scroll-wrapper").wrapInner('<div class="km-scroll-container"/>').prepend('<div class="km-scroll-header"/>');var a=t.children().eq(1),d=new i.TapCapture(t),u=new r(a),f=new h({element:a,container:t,forcedEnabled:s.options.zoom}),p=this.options.avoidScrolling,y=new i.UserEvents(t,{touchAction:"pan-y",fastTap:!0,allowSelection:!0,preventDragEvent:!0,captureUpIfMoved:!0,multiTouch:s.options.zoom,supportDoubleTap:s.options.supportDoubleTap,start:function(i){f.refresh();var t=m(i.x.velocity),n=m(i.y.velocity),l=2*t>=n,o=2*n>=t;!e.contains(s.fixedContainer[0],i.event.target)&&!p(i)&&s.enabled&&(f.x.enabled&&l||f.y.enabled&&o)?y.capture():y.cancel()}}),_=new c({movable:u,dimensions:f,userEvents:y,elastic:s.options.elastic}),w=new x({movable:u,dimensions:f,userEvents:y,tapCapture:d}),g=new T({moveTo:function(e){s.scrollTo(e.x,e.y)}});u.bind(v,(function(){s.scrollTop=-u.y,s.scrollLeft=-u.x,s.trigger(b,{scrollTop:s.scrollTop,scrollLeft:s.scrollLeft})})),s.options.mousewheelScrolling&&t.on("DOMMouseScroll mousewheel",this._wheelScroll.bind(this)),l(s,{movable:u,dimensions:f,zoomSnapBack:w,animatedScroller:g,userEvents:y,pane:_,tapCapture:d,pulled:!1,enabled:!0,scrollElement:a,scrollTop:0,scrollLeft:0,fixedContainer:t.children().first()}),s._initAxis("x"),s._initAxis("y"),s._wheelEnd=function(){s._wheel=!1,s.userEvents.end(0,s._wheelY)},f.refresh(),s.options.pullToRefresh&&s._initPullToRefresh()},_wheelScroll:function(e){if(!e.ctrlKey){this._wheel||(this._wheel=!0,this._wheelY=0,this.userEvents.press(0,this._wheelY)),clearTimeout(this._wheelTimeout),this._wheelTimeout=setTimeout(this._wheelEnd,50);var t=i.wheelDeltaY(e);t&&(this._wheelY+=t,this.userEvents.move(0,this._wheelY)),e.preventDefault()}},makeVirtual:function(){this.dimensions.y.makeVirtual()},virtualSize:function(e,i){this.dimensions.y.virtualSize(e,i)},height:function(){return this.dimensions.y.size},scrollHeight:function(){return this.scrollElement[0].scrollHeight},scrollWidth:function(){return this.scrollElement[0].scrollWidth},options:{name:"Scroller",zoom:!1,pullOffset:140,visibleScrollHints:!1,elastic:!0,useNative:!1,mousewheelScrolling:!0,avoidScrolling:function(){return!1},pullToRefresh:!1,messages:{pullTemplate:"Pull to refresh",releaseTemplate:"Release to refresh",refreshTemplate:"Refreshing"}},events:["pull",b,"resize"],_resize:function(){this._native||this.contentResized()},setOptions:function(e){o.fn.setOptions.call(this,e),e.pullToRefresh&&this._initPullToRefresh()},reset:function(){this._native?this.scrollElement.scrollTop(0):(this.movable.moveTo({x:0,y:0}),this._scale(1))},contentResized:function(){this.dimensions.refresh(),this.pane.x.outOfBounds()&&this.movable.moveAxis("x",this.dimensions.x.min),this.pane.y.outOfBounds()&&this.movable.moveAxis("y",this.dimensions.y.min)},zoomOut:function(){var e=this.dimensions;e.refresh(),this._scale(e.fitScale),this.movable.moveTo(e.centerCoordinates())},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},scrollTo:function(e,t){this._native?(i.scrollLeft(this.scrollElement,m(e)),this.scrollElement.scrollTop(m(t))):(this.dimensions.refresh(),this.movable.moveTo({x:e,y:t}))},animatedScrollTo:function(e,i,t){var n,s;this._native?this.scrollTo(e,i):(n={x:this.movable.x,y:this.movable.y},s={x:e,y:i},this.animatedScroller.setCoordinates(n,s),this.animatedScroller.setCallback(t),this.animatedScroller.start())},pullHandled:function(){var e=this;e.refreshHint.removeClass(p),e.hintContainer.html(e.pullTemplate({})),e.yinertia.onEnd(),e.xinertia.onEnd(),e.userEvents.cancel()},destroy:function(){o.fn.destroy.call(this),this.userEvents&&this.userEvents.destroy()},_scale:function(e){this.dimensions.rescale(e),this.movable.scaleTo(e)},_initPullToRefresh:function(){var e=this;e.dimensions.y.forceEnabled(),e.pullTemplate=i.template(e.options.messages.pullTemplate),e.releaseTemplate=i.template(e.options.messages.releaseTemplate),e.refreshTemplate=i.template(e.options.messages.refreshTemplate),e.scrollElement.prepend('<span class="km-scroller-pull"><span class="km-icon"></span><span class="km-loading-left"></span><span class="km-loading-right"></span><span class="km-template">'+e.pullTemplate({})+"</span></span>"),e.refreshHint=e.scrollElement.children().first(),e.hintContainer=e.refreshHint.children(".km-template"),e.pane.y.bind("change",e._paneChange.bind(e)),e.userEvents.bind("end",e._dragEnd.bind(e))},_dragEnd:function(){var e=this;e.pulled&&(e.pulled=!1,e.refreshHint.removeClass(f).addClass(p),e.hintContainer.html(e.refreshTemplate({})),e.yinertia.freeze(e.options.pullOffset/2),e.trigger("pull"))},_paneChange:function(){var e=this;e.movable.y/.5>e.options.pullOffset?e.pulled||(e.pulled=!0,e.refreshHint.removeClass(p).addClass(f),e.hintContainer.html(e.releaseTemplate({}))):e.pulled&&(e.pulled=!1,e.refreshHint.removeClass(f),e.hintContainer.html(e.pullTemplate({})))},_initAxis:function(e){var t,n=this,s=n.element.attr("id"),l=n.movable,o=n.dimensions[e],a=n.tapCapture,r=n.pane[e];s||(s=i.guid(),n.element.attr("id",s)),t=new _({axis:e,movable:l,dimension:o,container:n.element,alwaysVisible:n.options.visibleScrollHints,controlsId:s}),o.bind(v,(function(){t.refresh()})),r.bind(v,(function(){t.show()})),n[e+"inertia"]=new y({axis:e,paneAxis:r,movable:l,tapCapture:a,userEvents:n.userEvents,dimension:o,elastic:n.options.elastic,friction:n.options.friction||.96,velocityMultiplier:n.options.velocityMultiplier||10,end:function(){t.hide(),n.trigger("scrollEnd",{axis:e,scrollTop:n.scrollTop,scrollLeft:n.scrollLeft})}})}}),s.plugin(w)}));
//# sourceMappingURL=kendo.mobile.scroller.min.js.map