summaryrefslogtreecommitdiffstats
path: root/devtools/client/responsive.html/test/browser/touch.html
blob: 98aeac68fde40594c3925a0fafda5d6ed92d5b36 (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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<!DOCTYPE html>

<meta charset="utf-8" />
<meta name="viewport" />
<title>test</title>


<style>
  div {
    border :1px solid red;
    width: 100px; height: 100px;
  }
</style>

<div data-is-delay="false"></div>

<script type="text/javascript;version=1.8">
  "use strict";
  let div = document.querySelector("div");
  let initX, initY;
  let previousEvent = "", touchendTime = 0;
  let updatePreviousEvent = function (e) {
    previousEvent = e.type;
  };

  div.style.transform = "none";
  div.style.backgroundColor = "";

  div.addEventListener("touchstart", function (evt) {
    let touch = evt.changedTouches[0];
    initX = touch.pageX;
    initY = touch.pageY;
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("touchmove", function (evt) {
    let touch = evt.changedTouches[0];
    let deltaX = touch.pageX - initX;
    let deltaY = touch.pageY - initY;
    div.style.transform = "translate(" + deltaX + "px, " + deltaY + "px)";
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("touchend", function (evt) {
    if (!evt.touches.length) {
      div.style.transform = "none";
    }
    touchendTime = performance.now();
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mouseenter", function (evt) {
    div.style.backgroundColor = "red";
    updatePreviousEvent(evt);
  }, true);
  div.addEventListener("mouseover", function(evt) {
    div.style.backgroundColor = "red";
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mouseout", function (evt) {
    div.style.backgroundColor = "blue";
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mouseleave", function (evt) {
    div.style.backgroundColor = "blue";
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mousedown", function (evt) {
    if (previousEvent === "touchend" && touchendTime !== 0) {
      let now = performance.now();
      div.dataset.isDelay = ((now - touchendTime) >= 300);
    } else {
      div.dataset.isDelay = false;
    }
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mousemove", updatePreviousEvent, true);

  div.addEventListener("mouseup", updatePreviousEvent, true);

  div.addEventListener("click", updatePreviousEvent, true);
</script>