UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

319 lines (257 loc) • 10.1 kB
"use strict"; var $ = require("../../core/renderer"), Callbacks = require("../../core/utils/callbacks"), each = require("../../core/utils/iterator").each, commonUtils = require("../../core/utils/common"), extend = require("../../core/utils/extend").extend, math = Math, simulatedStrategy = require("./ui.scrollable.simulated"), LoadIndicator = require("../load_indicator"); 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; var ScrollViewScroller = simulatedStrategy.Scroller.inherit({ ctor: function ctor() { this._topPocketSize = 0; this.callBase.apply(this, arguments); this._initCallbacks(); this._releaseState(); }, _releaseState: function _releaseState() { this._state = STATE_RELEASED; this._refreshPullDownText(); }, _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); }); }, _initCallbacks: function _initCallbacks() { this.pullDownCallbacks = Callbacks(); this.releaseCallbacks = Callbacks(); this.reachBottomCallbacks = Callbacks(); }, _updateBounds: function _updateBounds() { var considerPockets = this._direction !== "horizontal"; this._topPocketSize = considerPockets ? this._$topPocket[this._dimension]() : 0; this._bottomPocketSize = considerPockets ? this._$bottomPocket[this._dimension]() : 0; this.callBase(); this._bottomBound = this._minOffset + this._bottomPocketSize; }, _updateScrollbar: function _updateScrollbar() { this._scrollbar.option({ containerSize: this._containerSize(), contentSize: this._contentSize() - this._topPocketSize - this._bottomPocketSize }); }, _moveContent: function _moveContent() { this.callBase(); if (this._isPullDown()) { this._pullDownReady(); } else if (this._isReachBottom()) { this._reachBottomReady(); } else if (this._state !== STATE_RELEASED) { this._stateReleased(); } }, _moveScrollbar: function _moveScrollbar() { this._scrollbar.moveTo(this._topPocketSize + this._location); }, _isPullDown: function _isPullDown() { return this._pullDownEnabled && this._location >= 0; }, _isReachBottom: function _isReachBottom() { return this._reachBottomEnabled && this._location <= this._bottomBound; }, _scrollComplete: function _scrollComplete() { if (this._inBounds() && this._state === STATE_READY) { this._pullDownRefreshing(); } else if (this._inBounds() && this._state === STATE_LOADING) { this._reachBottomLoading(); } else { this.callBase(); } }, _reachBottomReady: function _reachBottomReady() { if (this._state === STATE_LOADING) { return; } this._state = STATE_LOADING; this._minOffset = this._getMinOffset(); }, _getMaxOffset: function _getMaxOffset() { return -this._topPocketSize; }, _getMinOffset: function _getMinOffset() { return math.min(this.callBase(), -this._topPocketSize); }, _reachBottomLoading: function _reachBottomLoading() { this.reachBottomCallbacks.fire(); }, _pullDownReady: function _pullDownReady() { if (this._state === STATE_READY) { return; } this._state = STATE_READY; this._maxOffset = 0; this._$pullDown.addClass(SCROLLVIEW_PULLDOWN_READY_CLASS); this._refreshPullDownText(); }, _stateReleased: function _stateReleased() { if (this._state === STATE_RELEASED) { return; } this._releaseState(); this._updateBounds(); this._$pullDown.removeClass(SCROLLVIEW_PULLDOWN_REFRESHING_CLASS).removeClass(SCROLLVIEW_PULLDOWN_READY_CLASS); this.releaseCallbacks.fire(); }, _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(); }, _releaseHandler: function _releaseHandler() { if (this._state === STATE_RELEASED) { this._moveToBounds(); } this._update(); if (this._releaseTask) { this._releaseTask.abort(); } this._releaseTask = commonUtils.executeAsync(this._release.bind(this)); return this._releaseTask.promise; }, _release: function _release() { this._stateReleased(); this._scrollComplete(); }, _reachBottomEnablingHandler: function _reachBottomEnablingHandler(enabled) { if (this._reachBottomEnabled === enabled) { return; } this._reachBottomEnabled = enabled; this._updateBounds(); }, _pullDownEnablingHandler: function _pullDownEnablingHandler(enabled) { if (this._pullDownEnabled === enabled) { return; } this._pullDownEnabled = enabled; this._considerTopPocketChange(); this._updateHandler(); }, _considerTopPocketChange: function _considerTopPocketChange() { this._location -= this._$topPocket.height() || -this._topPocketSize; this._maxOffset = 0; this._move(); }, _pendingReleaseHandler: function _pendingReleaseHandler() { this._state = STATE_READY; }, dispose: function dispose() { if (this._releaseTask) { this._releaseTask.abort(); } this.callBase(); } }); var SimulatedScrollViewStrategy = simulatedStrategy.SimulatedStrategy.inherit({ _init: function _init(scrollView) { this.callBase(scrollView); this._$pullDown = scrollView._$pullDown; this._$topPocket = scrollView._$topPocket; this._$bottomPocket = scrollView._$bottomPocket; this._initCallbacks(); }, _initCallbacks: function _initCallbacks() { this.pullDownCallbacks = Callbacks(); this.releaseCallbacks = Callbacks(); this.reachBottomCallbacks = Callbacks(); }, render: function render() { this._renderPullDown(); this.callBase(); }, _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); }, pullDownEnable: function pullDownEnable(enabled) { this._eventHandler("pullDownEnabling", enabled); }, reachBottomEnable: function reachBottomEnable(enabled) { this._eventHandler("reachBottomEnabling", enabled); }, _createScroller: function _createScroller(direction) { var that = this; var scroller = that._scrollers[direction] = new ScrollViewScroller(that._scrollerOptions(direction)); scroller.pullDownCallbacks.add(function () { that.pullDownCallbacks.fire(); }); scroller.releaseCallbacks.add(function () { that.releaseCallbacks.fire(); }); scroller.reachBottomCallbacks.add(function () { that.reachBottomCallbacks.fire(); }); }, _scrollerOptions: function _scrollerOptions(direction) { return extend(this.callBase(direction), { $topPocket: this._$topPocket, $bottomPocket: this._$bottomPocket, $pullDown: this._$pullDown, $pullDownText: this._$pullDownText, $pullingDownText: this._$pullingDownText, $pulledDownText: this._$pulledDownText, $refreshingText: this._$refreshingText }); }, pendingRelease: function pendingRelease() { this._eventHandler("pendingRelease"); }, release: function release() { return this._eventHandler("release").done(this._updateAction); }, location: function location() { var location = this.callBase(); location.top += this._$topPocket.height(); return location; }, dispose: function dispose() { each(this._scrollers, function () { this.dispose(); }); this.callBase(); } }); module.exports = SimulatedScrollViewStrategy;