| OLD | NEW | 
|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 import '../resources/third_party/unittest/unittest.dart'; | 5 import '../resources/third_party/unittest/unittest.dart'; | 
| 6 import '../resources/unit.dart'; | 6 import '../resources/unit.dart'; | 
| 7 import 'dart:sky' as sky; | 7 import 'dart:sky' as sky; | 
| 8 import 'package:sky/framework/app.dart'; | 8 import 'package:sky/framework/app.dart'; | 
| 9 import 'package:sky/framework/layout2.dart'; | 9 import 'package:sky/framework/layout2.dart'; | 
| 10 | 10 | 
| 11 class RenderSolidColor extends RenderDecoratedBox { | 11 class RenderSolidColor extends RenderDecoratedBox { | 
| 12   final sky.Size desiredSize; | 12   final sky.Size desiredSize; | 
| 13   final int backgroundColor; | 13   final int backgroundColor; | 
| 14 | 14 | 
| 15   RenderSolidColor(int backgroundColor, { this.desiredSize: const sky.Size.infin
    ite() }) | 15   RenderSolidColor(int backgroundColor, { this.desiredSize: const sky.Size.infin
    ite() }) | 
| 16       : backgroundColor = backgroundColor, | 16       : backgroundColor = backgroundColor, | 
| 17         super(new BoxDecoration(backgroundColor: backgroundColor)) { | 17         super(decoration: new BoxDecoration(backgroundColor: backgroundColor)) { | 
| 18   } | 18   } | 
| 19 | 19 | 
| 20   sky.Size getIntrinsicDimensions(BoxConstraints constraints) { | 20   sky.Size getIntrinsicDimensions(BoxConstraints constraints) { | 
| 21     return constraints.constrain(desiredSize); | 21     return constraints.constrain(desiredSize); | 
| 22   } | 22   } | 
| 23 | 23 | 
| 24   void performLayout() { | 24   void performLayout() { | 
| 25     size = constraints.constrain(desiredSize); | 25     size = constraints.constrain(desiredSize); | 
| 26   } | 26   } | 
| 27 | 27 | 
| 28   void handlePointer(sky.PointerEvent event) { | 28   void handlePointer(sky.PointerEvent event) { | 
| 29     if (event.type == 'pointerdown') | 29     if (event.type == 'pointerdown') | 
| 30       decoration = new BoxDecoration(backgroundColor: 0xFFFF0000); | 30       decoration = new BoxDecoration(backgroundColor: 0xFFFF0000); | 
| 31     else if (event.type == 'pointerup') | 31     else if (event.type == 'pointerup') | 
| 32       decoration = new BoxDecoration(backgroundColor: backgroundColor); | 32       decoration = new BoxDecoration(backgroundColor: backgroundColor); | 
| 33   } | 33   } | 
| 34 } | 34 } | 
| 35 | 35 | 
| 36 AppView app; | 36 AppView app; | 
| 37 | 37 | 
| 38 void main() { | 38 void main() { | 
| 39   initUnit(); | 39   initUnit(); | 
| 40 | 40 | 
| 41   test("should flex", () { | 41   test("should flex", () { | 
| 42     var root = new RenderFlex( | 42     RenderFlex flexRoot = new RenderFlex(direction: FlexDirection.Vertical); | 
| 43         direction: FlexDirection.Vertical, |  | 
| 44         decoration: new BoxDecoration(backgroundColor: 0xFF000000)); |  | 
| 45 | 43 | 
| 46     void addFlexChild(RenderFlex parent, int backgroundColor, { int flex: 0 }) { | 44     RenderNode root = new RenderDecoratedBox( | 
|  | 45       decoration: new BoxDecoration(backgroundColor: 0xFF000000), | 
|  | 46       child: flexRoot | 
|  | 47     ); | 
|  | 48 | 
|  | 49     void addFlexChildSolidColor(RenderFlex parent, int backgroundColor, { int fl
    ex: 0 }) { | 
| 47       RenderNode child = new RenderSolidColor(backgroundColor); | 50       RenderNode child = new RenderSolidColor(backgroundColor); | 
| 48       parent.add(child); | 51       parent.add(child); | 
| 49       child.parentData.flex = flex; | 52       child.parentData.flex = flex; | 
| 50     } | 53     } | 
| 51 | 54 | 
| 52     // Yellow bar at top | 55     // Yellow bar at top | 
| 53     addFlexChild(root, 0xFFFFFF00, flex: 1); | 56     addFlexChildSolidColor(flexRoot, 0xFFFFFF00, flex: 1); | 
| 54 | 57 | 
| 55     // Turquoise box | 58     // Turquoise box | 
| 56     root.add(new RenderSolidColor(0x7700FFFF, desiredSize: new sky.Size(100.0, 1
    00.0))); | 59     flexRoot.add(new RenderSolidColor(0x7700FFFF, desiredSize: new sky.Size(100.
    0, 100.0))); | 
| 57 | 60 | 
| 58     // Green and cyan render block with padding | 61     // Green and cyan render block with padding | 
| 59     var renderBlock = new RenderBlock(decoration: new BoxDecoration(backgroundCo
    lor: 0xFFFFFFFF)); | 62     var renderBlock = new RenderBlock(); | 
| 60 | 63 | 
| 61     renderBlock.add(new RenderSolidColor(0xFF00FF00, desiredSize: new sky.Size(1
    00.0, 50.0))); | 64     renderBlock.add(new RenderSolidColor(0xFF00FF00, desiredSize: new sky.Size(1
    00.0, 50.0))); | 
| 62     renderBlock.add(new RenderSolidColor(0x7700FFFF, desiredSize: new sky.Size(5
    0.0, 100.0))); | 65     renderBlock.add(new RenderSolidColor(0x7700FFFF, desiredSize: new sky.Size(5
    0.0, 100.0))); | 
| 63 | 66 | 
| 64     root.add(new RenderPadding(const EdgeDims(10.0, 10.0, 10.0, 10.0), renderBlo
    ck)); | 67     var renderDecoratedBlock = new RenderDecoratedBox( | 
|  | 68       decoration: new BoxDecoration(backgroundColor: 0xFFFFFFFF), | 
|  | 69       child: renderBlock | 
|  | 70     ); | 
| 65 | 71 | 
| 66     var row = new RenderFlex( | 72     flexRoot.add(new RenderPadding(const EdgeDims(10.0, 10.0, 10.0, 10.0), rende
    rDecoratedBlock)); | 
| 67       direction: FlexDirection.Horizontal, | 73 | 
| 68       decoration: new BoxDecoration(backgroundColor: 0xFF333333)); | 74     var row = new RenderFlex(direction: FlexDirection.Horizontal); | 
| 69 | 75 | 
| 70     // Purple and blue cells | 76     // Purple and blue cells | 
| 71     addFlexChild(row, 0x77FF00FF, flex: 1); | 77     addFlexChildSolidColor(row, 0x77FF00FF, flex: 1); | 
| 72     addFlexChild(row, 0xFF0000FF, flex: 2); | 78     addFlexChildSolidColor(row, 0xFF0000FF, flex: 2); | 
| 73 | 79 | 
| 74     root.add(row); | 80     var decoratedRow = new RenderDecoratedBox( | 
| 75     row.parentData.flex = 3; | 81       decoration: new BoxDecoration(backgroundColor: 0xFF333333), | 
|  | 82       child: row | 
|  | 83     ); | 
|  | 84 | 
|  | 85     flexRoot.add(decoratedRow); | 
|  | 86     decoratedRow.parentData.flex = 3; | 
| 76 | 87 | 
| 77     app = new AppView(root); | 88     app = new AppView(root); | 
| 78 | 89 | 
| 79     expect(root.size.width, equals(sky.view.width)); | 90     expect(root.size.width, equals(sky.view.width)); | 
| 80     expect(root.size.height, equals(sky.view.height)); | 91     expect(root.size.height, equals(sky.view.height)); | 
| 81     expect(renderBlock.size.width, equals(sky.view.width - 20.0)); | 92     expect(renderBlock.size.width, equals(sky.view.width - 20.0)); | 
|  | 93 | 
| 82   }); | 94   }); | 
| 83 } | 95 } | 
| OLD | NEW | 
|---|