2018-11-12 21:18:45 +00:00
|
|
|
// Copyright 2010 The Closure Library Authors. All Rights Reserved.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS-IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @fileoverview Browser capability checks for the events package.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
goog.provide('goog.events.BrowserFeature');
|
|
|
|
|
|
|
|
goog.require('goog.userAgent');
|
2018-11-13 05:24:09 +00:00
|
|
|
goog.scope(function() {
|
|
|
|
|
2018-11-12 21:18:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enum of browser capabilities.
|
|
|
|
* @enum {boolean}
|
|
|
|
*/
|
|
|
|
goog.events.BrowserFeature = {
|
|
|
|
/**
|
|
|
|
* Whether the button attribute of the event is W3C compliant. False in
|
|
|
|
* Internet Explorer prior to version 9; document-version dependent.
|
|
|
|
*/
|
|
|
|
HAS_W3C_BUTTON:
|
|
|
|
!goog.userAgent.IE || goog.userAgent.isDocumentModeOrHigher(9),
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the browser supports full W3C event model.
|
|
|
|
*/
|
|
|
|
HAS_W3C_EVENT_SUPPORT:
|
|
|
|
!goog.userAgent.IE || goog.userAgent.isDocumentModeOrHigher(9),
|
|
|
|
|
|
|
|
/**
|
|
|
|
* To prevent default in IE7-8 for certain keydown events we need set the
|
|
|
|
* keyCode to -1.
|
|
|
|
*/
|
|
|
|
SET_KEY_CODE_TO_PREVENT_DEFAULT:
|
|
|
|
goog.userAgent.IE && !goog.userAgent.isVersionOrHigher('9'),
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the {@code navigator.onLine} property is supported.
|
|
|
|
*/
|
|
|
|
HAS_NAVIGATOR_ONLINE_PROPERTY:
|
|
|
|
!goog.userAgent.WEBKIT || goog.userAgent.isVersionOrHigher('528'),
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether HTML5 network online/offline events are supported.
|
|
|
|
*/
|
|
|
|
HAS_HTML5_NETWORK_EVENT_SUPPORT:
|
|
|
|
goog.userAgent.GECKO && goog.userAgent.isVersionOrHigher('1.9b') ||
|
|
|
|
goog.userAgent.IE && goog.userAgent.isVersionOrHigher('8') ||
|
|
|
|
goog.userAgent.OPERA && goog.userAgent.isVersionOrHigher('9.5') ||
|
|
|
|
goog.userAgent.WEBKIT && goog.userAgent.isVersionOrHigher('528'),
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether HTML5 network events fire on document.body, or otherwise the
|
|
|
|
* window.
|
|
|
|
*/
|
|
|
|
HTML5_NETWORK_EVENTS_FIRE_ON_BODY:
|
|
|
|
goog.userAgent.GECKO && !goog.userAgent.isVersionOrHigher('8') ||
|
|
|
|
goog.userAgent.IE && !goog.userAgent.isVersionOrHigher('9'),
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether touch is enabled in the browser.
|
|
|
|
*/
|
|
|
|
TOUCH_ENABLED:
|
|
|
|
('ontouchstart' in goog.global ||
|
|
|
|
!!(goog.global['document'] && document.documentElement &&
|
|
|
|
'ontouchstart' in document.documentElement) ||
|
|
|
|
// IE10 uses non-standard touch events, so it has a different check.
|
|
|
|
!!(goog.global['navigator'] &&
|
2018-11-13 05:24:09 +00:00
|
|
|
goog.global['navigator']['msMaxTouchPoints'])),
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether addEventListener supports {passive: true}.
|
|
|
|
* https://developers.google.com/web/updates/2016/06/passive-event-listeners
|
|
|
|
*/
|
|
|
|
PASSIVE_EVENTS: purify(function() {
|
|
|
|
// If we're in a web worker or other custom environment, we can't tell.
|
|
|
|
if (!goog.global.addEventListener || !Object.defineProperty) { // IE 8
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
var passive = false;
|
|
|
|
var options = Object.defineProperty({}, 'passive', {
|
|
|
|
get: function() {
|
|
|
|
passive = true;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
goog.global.addEventListener('test', goog.nullFunction, options);
|
|
|
|
goog.global.removeEventListener('test', goog.nullFunction, options);
|
|
|
|
|
|
|
|
return passive;
|
|
|
|
})
|
2018-11-12 21:18:45 +00:00
|
|
|
};
|
2018-11-13 05:24:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tricks Closure Compiler into believing that a function is pure. The compiler
|
|
|
|
* assumes that any `valueOf` function is pure, without analyzing its contents.
|
|
|
|
*
|
|
|
|
* @param {function(): T} fn
|
|
|
|
* @return {T}
|
|
|
|
* @template T
|
|
|
|
*/
|
|
|
|
function purify(fn) {
|
|
|
|
return ({valueOf: fn}).valueOf();
|
|
|
|
}
|
|
|
|
}); // goog.scope
|