OLD | NEW |
1 <!-- | 1 <!-- |
2 // Copyright 2015 The Chromium Authors. All rights reserved. | 2 // Copyright 2015 The Chromium Authors. All rights reserved. |
3 // Use of this source code is governed by a BSD-style license that can be | 3 // Use of this source code is governed by a BSD-style license that can be |
4 // found in the LICENSE file. | 4 // found in the LICENSE file. |
5 --> | 5 --> |
6 <import src="/sky/framework/sky-drawer.sky" /> | 6 <import src="/sky/framework/sky-drawer.sky" /> |
7 <import src="/sky/framework/sky-element.sky" /> | 7 <import src="/sky/framework/sky-element.sky" /> |
8 <import src="/sky/framework/sky-scrollable.sky" /> | 8 <import src="/sky/framework/sky-scrollable.sky" /> |
9 <import src="stock.sky" /> | 9 <import src="stock.sky" as='view'/> |
| 10 <import src='companylist.sky' as='model'/> |
10 | 11 |
11 <sky-element> | 12 <sky-element> |
12 <template> | 13 <template> |
13 <style> | 14 <style> |
14 :host { | 15 :host { |
15 display: flex; | 16 display: flex; |
16 flex-direction: column; | 17 flex-direction: column; |
17 height: -webkit-fill-available; | 18 height: -webkit-fill-available; |
18 } | 19 } |
19 sky-drawer { | 20 sky-drawer { |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
51 background-color: green; | 52 background-color: green; |
52 } | 53 } |
53 </style> | 54 </style> |
54 <sky-drawer id="drawer"> | 55 <sky-drawer id="drawer"> |
55 I am drawer | 56 I am drawer |
56 </sky-drawer> | 57 </sky-drawer> |
57 <sky-toolbar> | 58 <sky-toolbar> |
58 <div id="menu" /> | 59 <div id="menu" /> |
59 I am a stocks app | 60 I am a stocks app |
60 </sky-toolbar> | 61 </sky-toolbar> |
61 <sky-scrollable> | 62 <sky-scrollable id='stock_list'> |
62 <stock ticker="GOOG" /> | |
63 <stock ticker="GOOGL" /> | |
64 <stock ticker="GOOG" /> | |
65 <stock ticker="GOOG" /> | |
66 <stock ticker="GOOG" /> | |
67 <stock ticker="GOOG" /> | |
68 <stock ticker="GOOG" /> | |
69 <stock ticker="GOOG" /> | |
70 <stock ticker="GOOG" /> | |
71 <stock ticker="GOOG" /> | |
72 <stock ticker="GOOG" /> | |
73 <stock ticker="GOOG" /> | |
74 <stock ticker="GOOG" /> | |
75 <stock ticker="GOOG" /> | |
76 <stock ticker="GOOG" /> | |
77 <stock ticker="GOOG" /> | |
78 <stock ticker="GOOG" /> | |
79 <stock ticker="GOOG" /> | |
80 <stock ticker="GOOG" /> | |
81 <stock ticker="GOOG" /> | |
82 <stock ticker="GOOG" /> | |
83 </sky-scrollable> | 63 </sky-scrollable> |
84 </template> | 64 </template> |
85 <script> | 65 <script> |
86 import "dart:sky"; | 66 import "dart:sky"; |
87 | 67 |
88 @Tagname('stocks') | 68 @Tagname('stocks') |
89 class Stocks extends SkyElement { | 69 class Stocks extends SkyElement { |
90 Element _drawer; | 70 Element _drawer; |
91 | 71 |
92 void shadowRootReady() { | 72 void shadowRootReady() { |
93 _drawer = shadowRoot.getElementById('drawer'); | 73 _drawer = shadowRoot.getElementById('drawer'); |
94 Element menu = shadowRoot.getElementById('menu'); | 74 Element menu = shadowRoot.getElementById('menu'); |
95 menu.addEventListener('click', _handleMenuClick); | 75 menu.addEventListener('click', _handleMenuClick); |
| 76 populateStockList(); |
| 77 } |
| 78 |
| 79 void populateStockList() { |
| 80 Element stockList = shadowRoot.getElementById('stock_list'); |
| 81 // Limit to first 100 to avoid taking seconds to load. |
| 82 for (var i = 0; i < 100; i++) { |
| 83 model.Stock stock = model.oracle.stocks[i]; |
| 84 stockList.appendChild(new view.Stock()..ticker = stock.symbol); |
| 85 } |
96 } | 86 } |
97 | 87 |
98 void _handleMenuClick(_) { | 88 void _handleMenuClick(_) { |
99 _drawer.toggle(); | 89 _drawer.toggle(); |
100 } | 90 } |
101 } | 91 } |
102 | 92 |
103 _init(script) => register(script, Stocks); | 93 _init(script) => register(script, Stocks); |
104 </script> | 94 </script> |
105 </sky-element> | 95 </sky-element> |
OLD | NEW |