Limit Data

Firebase collections may contain huge amounts of data. Narrowing down and getting only the data you need makes applications more efficient and less expensive (cloud services are not always free).

There are three simple ways to limit the amount of data loaded into Collection objects:

  • Use the fields property to specify the fields you want to load.
  • Set the pageSize property to a reasonable number of records set the pageOnServer property to true.
  • Set the queryFilter property to an object that describes a filter to apply to the data.

This sample demonstrates all of these techniques.

Learn about FlexGrid | Limit Data Documentation | Cloud API Reference

app.js
index.html
styles.css
Copy to CodeMine
import 'bootstrap.css'; import '@mescius/wijmo.styles/wijmo.css'; import './styles.css'; import { Firestore, Collection } from '@mescius/wijmo.cloud'; import { ComboBox, CollectionViewNavigator } from '@mescius/wijmo.input'; import { FlexGrid } from '@mescius/wijmo.grid'; document.readyState === 'complete' ? init() : window.onload = init; function init() { // create the Firestore data source const API_KEY = 'AIzaSyBeEwDqO_h1KOMRekRrDizOZweSiTXRj2Y'; const PROJECT_ID = 'test-9c0be'; const fireStore = new Firestore(PROJECT_ID, API_KEY); // load the Customers collection (selected fields, server-side paging) const countries = 'Brazil,France,Germany,UK,USA'.split(','); const customers = new Collection(fireStore, 'Customers', { sortDescriptions: ['CustomerID'], fields: [ 'CustomerID', 'CompanyName', 'ContactName', 'City', 'Country' ], pageSize: 6, pageOnServer: true }).where('Country', '==', countries[0]); // filter the Collection by country new ComboBox('#cmbCountries', { itemsSource: countries, textChanged: (s, e) => { customers.where('Country', '==', s.text); customers.moveToFirstPage(); } }); // navigate the Collection by page new CollectionViewNavigator('#fsCustomerPager', { cv: customers, byPage: true, headerFormat: 'Page {current:n0}' }); // show the filtered/paged customers new FlexGrid('#fsCustomerGrid', { selectionMode: 'MultiRange', showMarquee: true, isReadOnly: true, autoGenerateColumns: false, columns: customers.fields.map(fld => { return { binding: fld }; }), itemsSource: customers }); }
import 'bootstrap.css'; import '@mescius/wijmo.styles/wijmo.css'; import './styles.css'; import { Firestore, Collection } from '@mescius/wijmo.cloud'; import { ComboBox, CollectionViewNavigator } from '@mescius/wijmo.input'; import { FlexGrid } from '@mescius/wijmo.grid'; document.readyState === 'complete' ? init() : window.onload = init; function init() { // create the Firestore data source const API_KEY = 'AIzaSyBeEwDqO_h1KOMRekRrDizOZweSiTXRj2Y'; const PROJECT_ID = 'test-9c0be'; const fireStore = new Firestore(PROJECT_ID, API_KEY); // load the Customers collection (selected fields, server-side paging) const countries = 'Brazil,France,Germany,UK,USA'.split(','); const customers = new Collection(fireStore, 'Customers', { sortDescriptions: ['CustomerID'], fields: [ 'CustomerID', 'CompanyName', 'ContactName', 'City', 'Country' ], pageSize: 6, pageOnServer: true }).where('Country', '==', countries[0]); // filter the Collection by country new ComboBox('#cmbCountries', { itemsSource: countries, textChanged: (s, e) => { customers.where('Country', '==', s.text); customers.moveToFirstPage(); } }); // navigate the Collection by page new CollectionViewNavigator('#fsCustomerPager', { cv: customers, byPage: true, headerFormat: 'Page {current:n0}' }); // show the filtered/paged customers new FlexGrid('#fsCustomerGrid', { selectionMode: 'MultiRange', showMarquee: true, isReadOnly: true, autoGenerateColumns: false, columns: customers.fields.map(fld => { return { binding: fld }; }), itemsSource: customers }); }
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>MESCIUS Wijmo Firestore Data Limits</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- SystemJS --> <script src="https://cdnjs.cloudflare.com/ajax/libs/systemjs/0.21.5/system.src.js" integrity="sha512-skZbMyvYdNoZfLmiGn5ii6KmklM82rYX2uWctBhzaXPxJgiv4XBwJnFGr5k8s+6tE1pcR1nuTKghozJHyzMcoA==" crossorigin="anonymous"></script> <script src="systemjs.config.js"></script> <script> System.import('./src/app'); </script> </head> <body> <div class="container-fluid"> <div id="cmbCountries"></div> <div id="fsCustomerPager"></div> <div id="fsCustomerGrid"></div> </div> </body> </html>
.wj-flexgrid { margin: 1em 0; } .wj-combobox { margin-right: 1em; }
(function (global) { System.config({ transpiler: 'plugin-babel', babelOptions: { es2015: true }, meta: { '*.css': { loader: 'css' } }, paths: { // paths serve as alias 'npm:': 'node_modules/' }, // map tells the System loader where to look for things map: { 'jszip': 'npm:jszip/dist/jszip.js', '@mescius/wijmo': 'npm:@mescius/wijmo/index.js', '@mescius/wijmo.input': 'npm:@mescius/wijmo.input/index.js', '@mescius/wijmo.styles': 'npm:@mescius/wijmo.styles', '@mescius/wijmo.cultures': 'npm:@mescius/wijmo.cultures', '@mescius/wijmo.chart': 'npm:@mescius/wijmo.chart/index.js', '@mescius/wijmo.chart.analytics': 'npm:@mescius/wijmo.chart.analytics/index.js', '@mescius/wijmo.chart.animation': 'npm:@mescius/wijmo.chart.animation/index.js', '@mescius/wijmo.chart.annotation': 'npm:@mescius/wijmo.chart.annotation/index.js', '@mescius/wijmo.chart.finance': 'npm:@mescius/wijmo.chart.finance/index.js', '@mescius/wijmo.chart.finance.analytics': 'npm:@mescius/wijmo.chart.finance.analytics/index.js', '@mescius/wijmo.chart.hierarchical': 'npm:@mescius/wijmo.chart.hierarchical/index.js', '@mescius/wijmo.chart.interaction': 'npm:@mescius/wijmo.chart.interaction/index.js', '@mescius/wijmo.chart.radar': 'npm:@mescius/wijmo.chart.radar/index.js', '@mescius/wijmo.chart.render': 'npm:@mescius/wijmo.chart.render/index.js', '@mescius/wijmo.chart.webgl': 'npm:@mescius/wijmo.chart.webgl/index.js', '@mescius/wijmo.chart.map': 'npm:@mescius/wijmo.chart.map/index.js', '@mescius/wijmo.gauge': 'npm:@mescius/wijmo.gauge/index.js', '@mescius/wijmo.grid': 'npm:@mescius/wijmo.grid/index.js', '@mescius/wijmo.grid.detail': 'npm:@mescius/wijmo.grid.detail/index.js', '@mescius/wijmo.grid.filter': 'npm:@mescius/wijmo.grid.filter/index.js', '@mescius/wijmo.grid.search': 'npm:@mescius/wijmo.grid.search/index.js', '@mescius/wijmo.grid.style': 'npm:@mescius/wijmo.grid.style/index.js', '@mescius/wijmo.grid.grouppanel': 'npm:@mescius/wijmo.grid.grouppanel/index.js', '@mescius/wijmo.grid.multirow': 'npm:@mescius/wijmo.grid.multirow/index.js', '@mescius/wijmo.grid.transposed': 'npm:@mescius/wijmo.grid.transposed/index.js', '@mescius/wijmo.grid.transposedmultirow': 'npm:@mescius/wijmo.grid.transposedmultirow/index.js', '@mescius/wijmo.grid.pdf': 'npm:@mescius/wijmo.grid.pdf/index.js', '@mescius/wijmo.grid.sheet': 'npm:@mescius/wijmo.grid.sheet/index.js', '@mescius/wijmo.grid.xlsx': 'npm:@mescius/wijmo.grid.xlsx/index.js', '@mescius/wijmo.grid.selector': 'npm:@mescius/wijmo.grid.selector/index.js', '@mescius/wijmo.grid.cellmaker': 'npm:@mescius/wijmo.grid.cellmaker/index.js', '@mescius/wijmo.nav': 'npm:@mescius/wijmo.nav/index.js', '@mescius/wijmo.odata': 'npm:@mescius/wijmo.odata/index.js', '@mescius/wijmo.olap': 'npm:@mescius/wijmo.olap/index.js', '@mescius/wijmo.rest': 'npm:@mescius/wijmo.rest/index.js', '@mescius/wijmo.pdf': 'npm:@mescius/wijmo.pdf/index.js', '@mescius/wijmo.pdf.security': 'npm:@mescius/wijmo.pdf.security/index.js', '@mescius/wijmo.viewer': 'npm:@mescius/wijmo.viewer/index.js', '@mescius/wijmo.xlsx': 'npm:@mescius/wijmo.xlsx/index.js', '@mescius/wijmo.undo': 'npm:@mescius/wijmo.undo/index.js', '@mescius/wijmo.interop.grid': 'npm:@mescius/wijmo.interop.grid/index.js', '@mescius/wijmo.touch': 'npm:@mescius/wijmo.touch/index.js', '@mescius/wijmo.cloud': 'npm:@mescius/wijmo.cloud/index.js', '@mescius/wijmo.barcode': 'npm:@mescius/wijmo.barcode/index.js', '@mescius/wijmo.barcode.common': 'npm:@mescius/wijmo.barcode.common/index.js', '@mescius/wijmo.barcode.composite': 'npm:@mescius/wijmo.barcode.composite/index.js', '@mescius/wijmo.barcode.specialized': 'npm:@mescius/wijmo.barcode.specialized/index.js', 'jszip': 'npm:jszip/dist/jszip.js', 'bootstrap.css': 'npm:bootstrap/dist/css/bootstrap.min.css', 'css': 'npm:systemjs-plugin-css/css.js', 'plugin-babel': 'npm:systemjs-plugin-babel/plugin-babel.js', 'systemjs-babel-build':'npm:systemjs-plugin-babel/systemjs-babel-browser.js' }, // packages tells the System loader how to load when no filename and/or no extension packages: { src: { defaultExtension: 'js' }, "node_modules": { defaultExtension: 'js' }, } }); })(this);