mirror of
https://github.com/dart-lang/sdk
synced 2024-11-05 18:22:09 +00:00
b101a7d002
Change-Id: Ib33169c3e0ffc870915c189404074a1dea472546 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/196548 Reviewed-by: Bob Nystrom <rnystrom@google.com> Commit-Queue: Leaf Petersen <leafp@google.com>
138 lines
4.2 KiB
Dart
138 lines
4.2 KiB
Dart
// 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.
|
|
|
|
// @dart = 2.9
|
|
|
|
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));
|
|
});
|
|
});
|
|
}
|