| // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| import 'dart:async'; |
| import 'dart:html'; |
| |
| import 'package:expect/minitest.dart'; |
| |
| main() { |
| void initPage() { |
| var level1 = new UListElement() |
| ..classes.add('level-1') |
| ..children.add(new LIElement()..innerHtml = 'I'); |
| var itemii = new LIElement() |
| ..classes.add('item-ii') |
| ..style.position = 'relative' |
| ..style.top = '4px' |
| ..innerHtml = 'II'; |
| level1.children.add(itemii); |
| var level2 = new UListElement(); |
| itemii.children.add(level2); |
| var itema = new LIElement() |
| ..classes.add('item-a') |
| ..innerHtml = 'A'; |
| var item1 = new LIElement() |
| ..classes.add('item-1') |
| ..innerHtml = '1'; |
| var item2 = new LIElement() |
| ..classes.add('item-2') |
| ..innerHtml = '2'; |
| var level3 = new UListElement()..children.addAll([item1, item2]); |
| var itemb = new LIElement() |
| ..classes.add('item-b') |
| ..style.position = 'relative' |
| ..style.top = '20px' |
| ..style.left = '150px' |
| ..innerHtml = 'B' |
| ..children.add(level3); |
| level2.children.addAll([itema, itemb, new LIElement()..innerHtml = 'C']); |
| document.body!.append(level1); |
| document.body!.style.whiteSpace = 'nowrap'; |
| |
| var bar = new DivElement()..classes.add('bar'); |
| var style = bar.style; |
| style |
| ..position = 'absolute' |
| ..top = '8px' |
| ..left = '90px'; |
| var baz = new DivElement()..classes.add('baz'); |
| style = baz.style; |
| style |
| ..position = 'absolute' |
| ..top = '600px' |
| ..left = '7000px'; |
| bar.children.add(baz); |
| |
| var quux = new DivElement()..classes.add('quux'); |
| var qux = new DivElement()..classes.add('qux')..children.add(quux); |
| |
| document.body!.append(bar); |
| document.body!.append(qux); |
| } |
| |
| group('offset', () { |
| setUp(initPage); |
| |
| test('offsetTo', () { |
| var itema = querySelector('.item-a')!; |
| var itemb = querySelector('.item-b')!; |
| var item1 = querySelector('.item-1')!; |
| var itemii = querySelector('.item-ii')!; |
| var level1 = querySelector('.level-1')!; |
| var baz = querySelector('.baz')!; |
| var bar = querySelector('.bar')!; |
| var qux = querySelector('.qux')!; |
| var quux = querySelector('.quux')!; |
| |
| var point = itema.offsetTo(itemii); |
| expect(point.x, 40); |
| expect(point.y, inInclusiveRange(16, 20)); |
| |
| expect(baz.offsetTo(bar).x, 7000); |
| expect(baz.offsetTo(bar).y, inInclusiveRange(599, 604)); |
| |
| qux.style.position = 'fixed'; |
| expect(quux.offsetTo(qux).x, 0); |
| expect(quux.offsetTo(qux).y, 0); |
| |
| point = item1.offsetTo(itemb); |
| expect(point.x, 40); |
| expect(point.y, inInclusiveRange(16, 20)); |
| point = itemb.offsetTo(itemii); |
| expect(point.x, 190); |
| expect(point.y, inInclusiveRange(52, 60)); |
| point = item1.offsetTo(itemii); |
| expect(point.x, 230); |
| expect(point.y, inInclusiveRange(68, 80)); |
| }); |
| |
| test('documentOffset', () { |
| var bar = querySelector('.bar')!; |
| var baz = querySelector('.baz')!; |
| var qux = querySelector('.qux')!; |
| var quux = querySelector('.quux')!; |
| var itema = querySelector('.item-a')!; |
| var itemb = querySelector('.item-b')!; |
| var item1 = querySelector('.item-1')!; |
| var itemii = querySelector('.item-ii')!; |
| |
| expect(itema.documentOffset.x, 88); |
| expect(itema.documentOffset.y, inInclusiveRange(111, 160)); |
| |
| expect(itemii.documentOffset.x, 48); |
| expect(itemii.documentOffset.y, inInclusiveRange(95, 145)); |
| |
| expect(itemb.documentOffset.x, 238); |
| expect(itemb.documentOffset.y, inInclusiveRange(147, 205)); |
| |
| expect(item1.documentOffset.x, 278); |
| expect(item1.documentOffset.y, inInclusiveRange(163, 222)); |
| |
| expect(bar.documentOffset.x, 90); |
| expect(bar.documentOffset.y, 8); |
| |
| expect(baz.documentOffset.x, 7090); |
| expect(baz.documentOffset.y, 608); |
| |
| expect(qux.documentOffset.x, 8); |
| expect(qux.documentOffset.y, inInclusiveRange(203, 240)); |
| |
| expect(quux.documentOffset.x, 8); |
| expect(quux.documentOffset.y, inInclusiveRange(203, 240)); |
| }); |
| }); |
| } |