UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

253 lines (206 loc) • 8.25 kB
"use strict"; var $ = require("../../core/renderer"), Callbacks = require("../../core/utils/callbacks"), translator = require("../../animation/translator"), NativeStrategy = require("./ui.scrollable.native"), LoadIndicator = require("../load_indicator"), each = require("../../core/utils/iterator").each, Deferred = require("../../core/utils/deferred").Deferred; var SCROLLVIEW_PULLDOWN_REFRESHING_CLASS = "dx-scrollview-pull-down-loading", SCROLLVIEW_PULLDOWN_READY_CLASS = "dx-scrollview-pull-down-ready", SCROLLVIEW_PULLDOWN_IMAGE_CLASS = "dx-scrollview-pull-down-image", SCROLLVIEW_PULLDOWN_INDICATOR_CLASS = "dx-scrollview-pull-down-indicator", SCROLLVIEW_PULLDOWN_TEXT_CLASS = "dx-scrollview-pull-down-text", SCROLLVIEW_PULLDOWN_VISIBLE_TEXT_CLASS = "dx-scrollview-pull-down-text-visible", STATE_RELEASED = 0, STATE_READY = 1, STATE_REFRESHING = 2, STATE_LOADING = 3, PULLDOWN_RELEASE_TIME = 400; var PullDownNativeScrollViewStrategy = NativeStrategy.inherit({ _init: function _init(scrollView) { this.callBase(scrollView); this._$topPocket = scrollView._$topPocket; this._$pullDown = scrollView._$pullDown; this._$bottomPocket = scrollView._$bottomPocket; this._$refreshingText = scrollView._$refreshingText; this._$scrollViewContent = $(scrollView.content()); this._initCallbacks(); }, _initCallbacks: function _initCallbacks() { this.pullDownCallbacks = Callbacks(); this.releaseCallbacks = Callbacks(); this.reachBottomCallbacks = Callbacks(); }, render: function render() { this.callBase(); this._renderPullDown(); this._releaseState(); }, _renderPullDown: function _renderPullDown() { var $image = $("<div>").addClass(SCROLLVIEW_PULLDOWN_IMAGE_CLASS), $loadContainer = $("<div>").addClass(SCROLLVIEW_PULLDOWN_INDICATOR_CLASS), $loadIndicator = new LoadIndicator($("<div>")).$element(), $text = this._$pullDownText = $("<div>").addClass(SCROLLVIEW_PULLDOWN_TEXT_CLASS); this._$pullingDownText = $("<div>").text(this.option("pullingDownText")).appendTo($text); this._$pulledDownText = $("<div>").text(this.option("pulledDownText")).appendTo($text); this._$refreshingText = $("<div>").text(this.option("refreshingText")).appendTo($text); this._$pullDown.empty().append($image).append($loadContainer.append($loadIndicator)).append($text); }, _releaseState: function _releaseState() { this._state = STATE_RELEASED; this._refreshPullDownText(); }, _pushBackFromBoundary: function _pushBackFromBoundary() { if (!this._isLocked() && !this._component.isEmpty()) { this.callBase(); } }, _refreshPullDownText: function _refreshPullDownText() { var that = this, pullDownTextItems = [{ element: this._$pullingDownText, visibleState: STATE_RELEASED }, { element: this._$pulledDownText, visibleState: STATE_READY }, { element: this._$refreshingText, visibleState: STATE_REFRESHING }]; each(pullDownTextItems, function (_, item) { var action = that._state === item.visibleState ? "addClass" : "removeClass"; item.element[action](SCROLLVIEW_PULLDOWN_VISIBLE_TEXT_CLASS); }); }, update: function update() { this.callBase(); this._setTopPocketOffset(); }, _updateDimensions: function _updateDimensions() { this.callBase(); this._topPocketSize = this._$topPocket.height(); this._bottomPocketSize = this._$bottomPocket.height(); this._scrollOffset = this._$container.height() - this._$content.height(); }, _allowedDirections: function _allowedDirections() { var allowedDirections = this.callBase(); allowedDirections.vertical = allowedDirections.vertical || this._pullDownEnabled; return allowedDirections; }, _setTopPocketOffset: function _setTopPocketOffset() { this._$topPocket.css({ top: -this._topPocketSize }); }, handleEnd: function handleEnd() { this.callBase(); this._complete(); }, handleStop: function handleStop() { this.callBase(); this._complete(); }, _complete: function _complete() { if (this._state === STATE_READY) { this._setPullDownOffset(this._topPocketSize); clearTimeout(this._pullDownRefreshTimeout); this._pullDownRefreshTimeout = setTimeout(function () { this._pullDownRefreshing(); }.bind(this), 400); } }, _setPullDownOffset: function _setPullDownOffset(offset) { translator.move(this._$topPocket, { top: offset }); translator.move(this._$scrollViewContent, { top: offset }); }, handleScroll: function handleScroll(e) { this.callBase(e); // TODO: replace with disabled check if (this._state === STATE_REFRESHING) { return; } var currentLocation = this.location().top, scrollDelta = (this._location || 0) - currentLocation; this._location = currentLocation; if (this._isPullDown()) { this._pullDownReady(); } else if (scrollDelta > 0 && this._isReachBottom()) { this._reachBottom(); } else { this._stateReleased(); } }, _isPullDown: function _isPullDown() { return this._pullDownEnabled && this._location >= this._topPocketSize; }, _isReachBottom: function _isReachBottom() { return this._reachBottomEnabled && this._location <= this._scrollOffset + this._bottomPocketSize; }, _reachBottom: function _reachBottom() { if (this._state === STATE_LOADING) { return; } this._state = STATE_LOADING; this.reachBottomCallbacks.fire(); }, _pullDownReady: function _pullDownReady() { if (this._state === STATE_READY) { return; } this._state = STATE_READY; this._$pullDown.addClass(SCROLLVIEW_PULLDOWN_READY_CLASS); this._refreshPullDownText(); }, _stateReleased: function _stateReleased() { if (this._state === STATE_RELEASED) { return; } this._$pullDown.removeClass(SCROLLVIEW_PULLDOWN_REFRESHING_CLASS).removeClass(SCROLLVIEW_PULLDOWN_READY_CLASS); this._releaseState(); }, _pullDownRefreshing: function _pullDownRefreshing() { if (this._state === STATE_REFRESHING) { return; } this._state = STATE_REFRESHING; this._$pullDown.addClass(SCROLLVIEW_PULLDOWN_REFRESHING_CLASS).removeClass(SCROLLVIEW_PULLDOWN_READY_CLASS); this._refreshPullDownText(); this.pullDownCallbacks.fire(); }, pullDownEnable: function pullDownEnable(enabled) { if (enabled) { this._updateDimensions(); this._setTopPocketOffset(); } this._pullDownEnabled = enabled; }, reachBottomEnable: function reachBottomEnable(enabled) { this._reachBottomEnabled = enabled; }, pendingRelease: function pendingRelease() { this._state = STATE_READY; }, release: function release() { var deferred = new Deferred(); this._updateDimensions(); clearTimeout(this._releaseTimeout); if (this._state === STATE_LOADING) { this._state = STATE_RELEASED; } this._releaseTimeout = setTimeout(function () { this._setPullDownOffset(0); this._stateReleased(); this.releaseCallbacks.fire(); this._updateAction(); deferred.resolve(); }.bind(this), PULLDOWN_RELEASE_TIME); return deferred.promise(); }, dispose: function dispose() { clearTimeout(this._pullDownRefreshTimeout); clearTimeout(this._releaseTimeout); this.callBase(); } }); module.exports = PullDownNativeScrollViewStrategy;