summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/css-flexbox/support/scrollbars.js
blob: 5b61b499c0fa49b5476339ed625d1687fe85cafc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
var flexDirections = ["row", "row-reverse", "column", "column-reverse"];
var textDirections = ["ltr", "rtl"];
var writingModes = ["horizontal", "flipped-blocks", "flipped-lines"];

var createLeafNode = (i) => {
  var flexItem = document.createElement("div");
  flexItem.className = "leaf" + i;
  var contentItem = document.createElement("div");
  contentItem.innerHTML = i;
  flexItem.appendChild(contentItem);
  return flexItem;
}

var createContentNode = (flexDirection, textDirection, writingMode) => {
  var flexNode = document.createElement("div");
  flexNode.className = "flex " + flexDirection;
  flexNode.title = "flex-direction: " + flexDirection + "; direction: " + textDirection + "; writing-mode: " + writingMode;
  for (var i = 1; i < 4; i++)
    flexNode.appendChild(createLeafNode(i));
  var marginShim = document.createElement("div");
  return flexNode;
}

var createContainerNode = (flexDirection, textDirection, writingMode) => {
  var containerNode = document.createElement("div");
  containerNode.className = "container " + textDirection + " " + writingMode;
  containerNode.appendChild(createContentNode(flexDirection, textDirection, writingMode));
  return containerNode;
}

var createContainerRow = (flexDirection) => {
  var containerRow = document.createElement("div");
  containerRow.className = "container-row";
  var rowLabel = document.createElement("div");
  rowLabel.className = "vertical-header horizontal " + flexDirection;
  rowLabel.innerHTML = flexDirection;
  containerRow.appendChild(rowLabel);
  textDirections.forEach((textDirection) => {
    writingModes.forEach((writingMode) => {
      var containerNode = createContainerNode(flexDirection, textDirection, writingMode);
      containerRow.appendChild(containerNode);
    });
  });
  return containerRow;
}