Commit ebc879ba authored by Hixie's avatar Hixie

[Effen] Prevent scrolling past the bottom of a scrollable list.

- make the ScrollBehavior instance long-lived, rather than recreating
  it each time we update the list contents.
- have OverscrollBehavior track the total height of the contents and
  the height of the scrollable region, so that it can determine when
  to stop scrolling down.
- teach OverscrollBehavior about how to determine when to stop
  scrolling down, and how to bounce when it's too far down.
- replace the 'energy' concept in Particles with a method that sets
  the energy and direction at the same time, instead of assuming that
  the direction is always positive when setting energy.
- make FixedHeightScrollable lists track the number of items in the
  list and have them update their ScrollBehavior regarding this
  information as it changes.
- track how many items are currently showing in the list stock list.

R=eseidel@chromium.org

Review URL: https://codereview.chromium.org/1097373002
parent 23283319
...@@ -16,12 +16,15 @@ class Stocklist extends FixedHeightScrollable { ...@@ -16,12 +16,15 @@ class Stocklist extends FixedHeightScrollable {
Object key, Object key,
this.stocks, this.stocks,
this.query this.query
}) : super(key: key, scrollBehavior: new OverscrollBehavior()); }) : super(key: key);
List<UINode> buildItems(int start, int count) { List<UINode> buildItems(int start, int count) {
return stocks var filteredStocks = stocks.where((stock) {
.where((stock) => query == null || stock.symbol.contains( return query == null ||
new RegExp(query, caseSensitive: false))) stock.symbol.contains(new RegExp(query, caseSensitive: false));
});
itemCount = filteredStocks.length;
return filteredStocks
.skip(start) .skip(start)
.take(count) .take(count)
.map((stock) => new StockRow(stock: stock)) .map((stock) => new StockRow(stock: stock))
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment