Blame view

node_modules/zrender/src/core/env.ts 3.12 KB
bd028579   易尊强   2/28
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
  declare const wx: {
      getSystemInfoSync: Function
  };
  
  class Browser {
      firefox = false
      ie = false
      edge = false
      newEdge = false
      weChat = false
      version: string | number
  }
  
  class Env {
      browser = new Browser()
      node = false
      wxa = false
      worker = false
  
      svgSupported = false
      touchEventsSupported = false
      pointerEventsSupported = false
      domSupported = false
      transformSupported = false
      transform3dSupported = false
  
      hasGlobalWindow = typeof window !== 'undefined'
  }
  
  const env = new Env();
  
  if (typeof wx === 'object' && typeof wx.getSystemInfoSync === 'function') {
      env.wxa = true;
      env.touchEventsSupported = true;
  }
  else if (typeof document === 'undefined' && typeof self !== 'undefined') {
      // In worker
      env.worker = true;
  }
  else if (
      typeof navigator === 'undefined'
      || navigator.userAgent.indexOf('Node.js') === 0
  ) {
      // In node
      env.node = true;
      env.svgSupported = true;
  }
  else {
      detect(navigator.userAgent, env);
  }
  
  // Zepto.js
  // (c) 2010-2013 Thomas Fuchs
  // Zepto.js may be freely distributed under the MIT license.
  
  function detect(ua: string, env: Env) {
      const browser = env.browser;
      const firefox = ua.match(/Firefox\/([\d.]+)/);
      const ie = ua.match(/MSIE\s([\d.]+)/)
          // IE 11 Trident/7.0; rv:11.0
          || ua.match(/Trident\/.+?rv:(([\d.]+))/);
      const edge = ua.match(/Edge?\/([\d.]+)/); // IE 12 and 12+
  
      const weChat = (/micromessenger/i).test(ua);
  
      if (firefox) {
          browser.firefox = true;
          browser.version = firefox[1];
      }
      if (ie) {
          browser.ie = true;
          browser.version = ie[1];
      }
  
      if (edge) {
          browser.edge = true;
          browser.version = edge[1];
          browser.newEdge = +edge[1].split('.')[0] > 18;
      }
  
      // It is difficult to detect WeChat in Win Phone precisely, because ua can
      // not be set on win phone. So we do not consider Win Phone.
      if (weChat) {
          browser.weChat = true;
      }
  
      env.svgSupported = typeof SVGRect !== 'undefined';
      env.touchEventsSupported = 'ontouchstart' in window && !browser.ie && !browser.edge;
      env.pointerEventsSupported = 'onpointerdown' in window
          && (browser.edge || (browser.ie && +browser.version >= 11));
      env.domSupported = typeof document !== 'undefined';
  
      const style = document.documentElement.style;
  
      env.transform3dSupported = (
          // IE9 only supports transform 2D
          // transform 3D supported since IE10
          // we detect it by whether 'transition' is in style
          (browser.ie && 'transition' in style)
          // edge
          || browser.edge
          // webkit
          || (('WebKitCSSMatrix' in window) && ('m11' in new WebKitCSSMatrix()))
          // gecko-based browsers
          || 'MozPerspective' in style
      ) // Opera supports CSS transforms after version 12
        && !('OTransition' in style);
  
      // except IE 6-8 and very old firefox 2-3 & opera 10.1
      // other browsers all support `transform`
      env.transformSupported = env.transform3dSupported
          // transform 2D is supported in IE9
          || (browser.ie && +browser.version >= 9);
  
  }
  
  
  export default env;