/*
This file is part of Ext JS 4.2
Copyright (c) 2011-2013 Sencha Inc
Contact: http://www.sencha.com/contact
GNU General Public License Usage
This file may be used under the terms of the GNU General Public License version 3.0 as
published by the Free Software Foundation and appearing in the file LICENSE included in the
packaging of this file.
Please review the following information to ensure the GNU General Public License version 3.0
requirements will be met: http://www.gnu.org/copyleft/gpl.html.
If you are unsure which license is appropriate for your use, please contact the sales department
at http://www.sencha.com/contact.
Build date: 2013-05-16 14:36:50 (f9be68accb407158ba2b1be2c226a6ce1f649314)
*/
/**
* @private
* A set of overrides required by the presence of the BufferedRenderer plugin.
*
* These overrides of Ext.view.Table take into account the affect of a buffered renderer and
* divert execution from the default course where necessary.
*/
Ext.define('Ext.grid.plugin.BufferedRendererTableView', {
override: 'Ext.view.Table',
// Listener function for the Store's add event
onAdd: function(store, records, index) {
var me = this,
bufferedRenderer = me.bufferedRenderer,
rows = me.all;
// The newly added records will put us over the buffered view size, so we cannot just add as normal.
if (me.rendered && bufferedRenderer && (rows.getCount() + records.length) > bufferedRenderer.viewSize) {
// Index puts the new row(s) in the visible area, then we have to refresh the view
if (index < rows.startIndex + bufferedRenderer.viewSize && (index + records.length) > rows.startIndex) {
me.refreshView();
}
// New rows outside of visible area, just ensure that the scroll range is updated
else {
bufferedRenderer.stretchView(me, bufferedRenderer.getScrollHeight());
}
}
// No BufferedRenderer present
// or
// View has not yet reached the viewSize: we can add as normal.
else {
me.callParent([store, records, index]);
}
},
onRemove: function(store, records, indices) {
var me = this,
bufferedRenderer = me.bufferedRenderer;
// Ensure all records are removed from the view
me.callParent([store, records, indices]);
// If there's a BufferedRenderer, the view must refresh to keep the view correct.
// Removing *may* have removed all of the rendered rows, leaving whitespace below the group header,
// so the refresh will be needed to keep the buffer rendered zone valid - to pull records up from
// below the removed zone into visibility.
if (me.rendered && bufferedRenderer) {
if (me.dataSource.getCount() > bufferedRenderer.viewSize) {
me.refreshView();
}
// No overflow, still we have to ensure the scroll range is updated
else {
bufferedRenderer.stretchView(me, bufferedRenderer.getScrollHeight());
}
}
},
// When there's a buffered renderer present, store refresh events cause TableViews to go to scrollTop:0
onDataRefresh: function() {
var me = this;
if (me.bufferedRenderer) {
// Clear NodeCache. Do NOT remove nodes from DOM - that would blur the view, and then refresh will not refocus after the refresh.
me.all.clear();
me.bufferedRenderer.onStoreClear();
}
me.callParent();
}
});
|