summaryrefslogtreecommitdiffstats
path: root/devtools/client/responsivedesign/test/touch.html
blob: f93d36f6c0c91360663d9576f7d72e17f249b74d (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
<!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>
  var div = document.querySelector("div");
  var initX, initY;
  var previousEvent = "", touchendTime = 0;
  var updatePreviousEvent = function(e){
    previousEvent = e.type;
  };

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

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

  div.addEventListener("touchmove", function(evt) {
    var touch = evt.changedTouches[0];
    var deltaX = touch.pageX - initX;
    var 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) ? true : false;
    } else {
      div.dataset.isDelay = false;
    }
    updatePreviousEvent(evt);
  }, true);

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

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

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