1
0
mirror of https://github.com/lancedikson/bowser synced 2024-10-27 20:34:22 +00:00

Merge branch 'release/1.7.0' into production

This commit is contained in:
Denis Demchenko 2017-05-18 21:55:58 +03:00
commit 246880c782
6 changed files with 86 additions and 9 deletions

View File

@ -1,5 +1,8 @@
# Bowser Changelog
### 1.7.0 (May 18, 2017)
- [ADD] Add OS version support for Windows and macOS (#178)
### 1.6.0 (December 5, 2016)
- [ADD] Add some tests for Windows devices (#89)
- [ADD] Add `root` to initialization process (#170)

View File

@ -22,7 +22,7 @@ Also you can download minified file from [the release page](https://github.com/d
## API
### bowser()`:Object`
### bowser`:Object`
Use it to get object with detected flags of your current browser.
### bowser._detect(ua `:String`)`:Object`
@ -155,7 +155,7 @@ If detected, one of these flags may be set to true:
`osversion` may also be set:
* `osversion` - for Android, iOS, Windows Phone, WebOS, Bada, and Tizen. If included in UA string.
* `osversion` - for Android, iOS, MacOS, Windows, Windows Phone, WebOS, Bada, and Tizen. If included in UA string.
iOS is always reported as `ios` and additionally as `iphone`/`ipad`/`ipod`, whichever one matches best.
If WebOS device is an HP TouchPad the flag `touchpad` is additionally set.
@ -201,5 +201,8 @@ See the list in `src/useragents.js` with example user agents and their expected
Whenever you add support for new browsers or notice a bug / mismatch, please update the list and
check if all tests are still passing.
### Similar Projects
* [Kong](https://github.com/BigBadBleuCheese/Kong) - A C# port of Bowser.
### License
Licensed as MIT. All rights not explicitly granted in the MIT license are reserved. See the included LICENSE file for more details.

View File

@ -11,13 +11,14 @@
"ender",
"sniff"
],
"version": "1.6.1",
"homepage": "https://github.com/ded/bowser",
"version": "1.7.0",
"homepage": "https://github.com/lancedikson/bowser",
"scripts": [
"src/bowser.js"
],
"authors": [
"Dustin Diaz <dustin@dustindiaz.com> (http://dustindiaz.com)"
"Dustin Diaz <dustin@dustindiaz.com> (http://dustindiaz.com)",
"Denis Demchenko <lance@dikson.me>"
],
"moduleType": [],
"license": "MIT",

View File

@ -1,6 +1,6 @@
{
"name": "bowser",
"version": "1.6.1",
"version": "1.7.0",
"description": "Lightweight browser detector",
"keywords": [
"browser",
@ -12,7 +12,7 @@
"ender",
"sniff"
],
"homepage": "https://github.com/ded/bowser",
"homepage": "https://github.com/lancedikson/bowser",
"author": "Dustin Diaz <dustin@dustindiaz.com> (http://dustindiaz.com)",
"main": "./src/bowser.js",
"typings": "./typings.d.ts",

View File

@ -336,10 +336,31 @@
result.linux = t
}
function getWindowsVersion (s) {
switch (s) {
case 'NT': return 'NT'
case 'XP': return 'XP'
case 'NT 5.0': return '2000'
case 'NT 5.1': return 'XP'
case 'NT 5.2': return '2003'
case 'NT 6.0': return 'Vista'
case 'NT 6.1': return '7'
case 'NT 6.2': return '8'
case 'NT 6.3': return '8.1'
case 'NT 10.0': return '10'
default: return undefined
}
}
// OS version extraction
var osVersion = '';
if (result.windowsphone) {
if (result.windows) {
osVersion = getWindowsVersion(getFirstMatch(/Windows ((NT|XP)( \d\d?.\d)?)/i))
} else if (result.windowsphone) {
osVersion = getFirstMatch(/windows phone (?:os)?\s?(\d+(\.\d+)*)/i);
} else if (result.mac) {
osVersion = getFirstMatch(/Mac OS X (\d+([_\.\s]\d+)*)/i);
osVersion = osVersion.replace(/[_\s]/g, '.');
} else if (iosdevice) {
osVersion = getFirstMatch(/os (\d+([_\s]\d+)*) like mac os x/i);
osVersion = osVersion.replace(/[_\s]/g, '.');
@ -359,7 +380,7 @@
}
// device type extraction
var osMajorVersion = osVersion.split('.')[0];
var osMajorVersion = !result.windows && osVersion.split('.')[0];
if (
tablet
|| nexusTablet

View File

@ -85,6 +85,7 @@ module.exports.useragents = {
chrome: true
, version: '30.0'
, windows: true
, osversion: '8'
, blink: true
, a: true
}
@ -92,6 +93,7 @@ module.exports.useragents = {
chrome: true
, version: '29.0'
, windows: true
, osversion: '7'
, blink: true
, a: true
}
@ -107,6 +109,7 @@ module.exports.useragents = {
chrome: true
, version: '29.0'
, windows: true
, osversion: '8'
, blink: true
, a: true
}
@ -114,6 +117,7 @@ module.exports.useragents = {
chrome: true
, version: '28.0'
, windows: true
, osversion: '7'
, blink: true
, a: true
}
@ -121,6 +125,7 @@ module.exports.useragents = {
chrome: true
, version: '11.0'
, mac: true
, osversion: '10.6.7'
, webkit: true
, c: true
}
@ -222,6 +227,7 @@ module.exports.useragents = {
, 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/28.0.1500.52 Safari/537.36 OPR/15.0.1147.100': {
opera: true
, windows: true
, osversion: '7'
, blink: true
, version: '15.0'
, a: true
@ -246,24 +252,28 @@ module.exports.useragents = {
opera: true
, version: '12.14'
, windows: true
, osversion: 'Vista'
, a: true
}
, 'Mozilla/5.0 (Windows NT 6.0; rv:2.0) Gecko/20100101 Firefox/4.0 Opera 12.14': {
opera: true
, version: '12.14'
, windows: true
, osversion: 'Vista'
, a: true
}
, 'Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.0) Opera 12.14': {
opera: true
, version: '12.14'
, windows: true
, osversion: 'Vista'
, a: true
}
, 'Opera/12.80 (Windows NT 5.1; U; en) Presto/2.10.289 Version/12.02': {
opera: true
, version: '12.02'
, windows: true
, osversion: 'XP'
, a: true
}
, 'Opera/9.80 (X11; Linux i686; U; es-ES) Presto/2.8.131 Version/11.11': {
@ -276,12 +286,14 @@ module.exports.useragents = {
opera: true
, version: '11.01'
, mac: true
, osversion: '10.6.7'
, a: true
}
, 'Opera/9.80 (Windows NT 5.2; U; zh-cn) Presto/2.6.30 Version/10.63': {
opera: true
, version: '10.63'
, windows: true
, osversion: '2003'
, a: true
}
, 'Opera/9.80 (X11; Linux i686; U; it) Presto/2.5.24 Version/10.54': {
@ -346,6 +358,7 @@ module.exports.useragents = {
, blink: true
, version: '15.4'
, mac: true
, osversion: '10.10.3'
, a: true
},
'Mozilla/5.0 (Linux; Android 5.1.1; Nexus 5 Build/LMY48B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 YaBrowser/15.4.2272.3608.00 Mobile Safari/537.36': {
@ -363,6 +376,7 @@ module.exports.useragents = {
safari: true
, version: '5.1'
, mac: true
, osversion: '10.6.8'
, webkit: true
, c: true
}
@ -370,6 +384,7 @@ module.exports.useragents = {
safari: true
, version: '5.0'
, mac: true
, osversion: '10.6.7'
, webkit: true
, c: true
}
@ -377,6 +392,7 @@ module.exports.useragents = {
safari: true
, version: '5.0'
, windows: true
, osversion: 'XP'
, webkit: true
, c: true
}
@ -391,6 +407,7 @@ module.exports.useragents = {
safari: true
, version: '4.1'
, windows: true
, osversion: '2000'
, webkit: true
, c: true
}
@ -398,6 +415,7 @@ module.exports.useragents = {
safari: true
, version: '4.0'
, mac: true
, osversion: '10.6.1'
, webkit: true
, c: true
}
@ -405,6 +423,7 @@ module.exports.useragents = {
safari: true
, version: '3.2'
, mac: true
, osversion: '10.5.7'
, webkit: true
, c: true
}
@ -575,72 +594,84 @@ module.exports.useragents = {
msie: true
, version: '11.0'
, windows: true
, osversion: '8.1'
, a: true
}
, 'Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; Touch; rv:11.0) like Gecko': {
msie: true
, version: '11.0'
, windows: true
, osversion: '8.1'
, a: true
}
, 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0; ARM; Touch; WPDesktop)': {
msie: true
, version: '10.0'
, windows: true
, osversion: '8'
, a: true
}
, 'Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; .NET4.0E; .NET4.0C; Media Center PC 6.0; rv:11.0) like Gecko': {
msie: true
, version: '11.0'
, windows: true
, osversion: '8.1'
, a: true
}
, 'Mozilla/5.0 (compatible; MSIE 10.6; Windows NT 6.1; Trident/5.0; InfoPath.2; SLCC1; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729; .NET CLR 2.0.50727) 3gpp-gba UNTRUSTED/1.0': {
msie: true
, version: '10.6'
, windows: true
, osversion: '7'
, a: true
}
, 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; Trident/4.0; InfoPath.2; SV1; .NET CLR 2.0.50727; WOW64)': {
msie: true
, version: '10.0'
, windows: true
, osversion: '7'
, a: true
}
, 'Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET CLR 2.0.50727; Media Center PC 6.0)': {
msie: true
, version: '9.0'
, windows: true
, osversion: '7'
, c: true
}
, 'Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; Trident/5.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C)': {
msie: true
, version: '8.0'
, windows: true
, osversion: '7'
, c: true
}
, 'Mozilla/4.0 (compatible; MSIE 7.0b; Windows NT 5.1; .NET CLR 1.1.4322; InfoPath.1; .NET CLR 2.0.50727)': {
msie: true
, version: '7.0'
, windows: true
, osversion: 'XP'
, c: true
}
, 'Mozilla/4.0 (compatible; MSIE 6.1; Windows XP; .NET CLR 1.1.4322; .NET CLR 2.0.50727)': {
msie: true
, version: '6.1'
, windows: true
, osversion: 'XP'
, c: true
}
, 'Mozilla/4.0 (Compatible; Windows NT 5.1; MSIE 6.0) (compatible; MSIE 6.0; Windows NT 5.1; .NET CLR 1.1.4322; .NET CLR 2.0.50727)': {
msie: true
, version: '6.0'
, windows: true
, osversion: 'XP'
, c: true
}
, 'Mozilla/4.0 (compatible; MSIE 5.01; Windows NT)': {
msie: true
, version: '5.01'
, windows: true
, osversion: 'NT'
, c: true
}
, 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0; Xbox; Xbox One)': {
@ -654,12 +685,14 @@ module.exports.useragents = {
, version: '11.0'
, a: true
, windows: true
, osversion: '8.1'
}
, 'Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; Touch; LCTE; rv:11.0)': {
msie: true
, version: '11.0'
, a: true
, windows: true
, osversion: '10'
}
}
, 'Microsoft Edge': {
@ -667,6 +700,7 @@ module.exports.useragents = {
msedge: true
, version: '12.0'
, windows: true
, osversion: '10'
, a: true
}
}
@ -716,6 +750,7 @@ module.exports.useragents = {
, firefox: true
, version: '25.0'
, windows: true
, osversion: '7'
, a: true
}
, 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:24.0) Gecko/20100101 Firefox/24.0': {
@ -723,6 +758,7 @@ module.exports.useragents = {
, firefox: true
, version: '24.0'
, mac: true
, osversion: '10.8'
, a: true
}
, 'Mozilla/5.0 (X11; Linux i686; rv:21.0) Gecko/20100101 Firefox/21.0': {
@ -751,6 +787,7 @@ module.exports.useragents = {
, firefox: true
, version: '15.0'
, windows: true
, osversion: '8'
, c: true
}
, 'Mozilla/5.0 (Windows; U; Windows NT 6.1; WOW64; en-US; rv:2.0.4) Gecko/20120718 AskTbAVR-IDW/3.12.5.17700 Firefox/14.0.1': {
@ -758,6 +795,7 @@ module.exports.useragents = {
, firefox: true
, version: '14.0'
, windows: true
, osversion: '7'
, c: true
}
, 'Mozilla/5.0 (Windows NT 5.1; rv:6.0) Gecko/20100101 Firefox/6.0 FirePHP/0.6': {
@ -765,6 +803,7 @@ module.exports.useragents = {
, firefox: true
, version: '6.0'
, windows: true
, osversion: 'XP'
, c: true
}
, 'Mozilla/5.0 (X11; Linux x86_64; rv:2.2a1pre) Gecko/20100101 Firefox/4.2a1pre': {
@ -779,6 +818,7 @@ module.exports.useragents = {
, firefox: true
, version: '4.0'
, mac: true
, osversion: '10.6'
, c: true
}
, 'Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.2b1) Gecko/20091014 Firefox/3.6b1 GTB5': {
@ -786,6 +826,7 @@ module.exports.useragents = {
, firefox: true
, version: '3.6'
, windows: true
, osversion: '7'
, c: true
}
, 'Mozilla/5.0 (Windows; U; Windows NT 6.0; de; rv:1.9.0.15) Gecko/2009101601 Firefox 2.1 (.NET CLR 3.5.30729)': {
@ -793,6 +834,7 @@ module.exports.useragents = {
, firefox: true
, version: '2.1'
, windows: true
, osversion: 'Vista'
, c: true
}
, 'Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.8.0.7) Gecko/20061014 Firefox/1.5.0.7': {
@ -819,6 +861,7 @@ module.exports.useragents = {
, seamonkey: true
, version: '2.7'
, windows: true
, osversion: '2003'
, x: true
}
, 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.5; rv:10.0.1) Gecko/20100101 Firefox/10.0.1 SeaMonkey/2.7.1': {
@ -826,6 +869,7 @@ module.exports.useragents = {
, seamonkey: true
, version: '2.7'
, mac: true
, osversion: '10.5'
, x: true
}
, 'Mozilla/5.0 (X11; Linux i686; rv:10.0.1) Gecko/20100101 Firefox/10.0.1 SeaMonkey/2.7.1': {
@ -1159,6 +1203,7 @@ module.exports.useragents = {
vivaldi: true
, version: '1.0'
, mac: true
, osversion: '10.11.1'
, blink: true
, a: true
},
@ -1166,6 +1211,7 @@ module.exports.useragents = {
vivaldi: true
, version: '1.0'
, windows: true
, osversion: '10'
, blink: true
, a: true
}
@ -1225,6 +1271,7 @@ module.exports.useragents = {
},
'Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.21 (KHTML, like Gecko) QupZilla/1.8.6 Safari/537.21': {
windows: true,
osversion: '8',
qupzilla: true,
version: '1.8.6',
webkit: true,
@ -1265,6 +1312,7 @@ module.exports.useragents = {
sleipnir: true
, blink: true
, windows: true
, osversion: '7'
, x: true
, version: '6.1.4'
}
@ -1272,6 +1320,7 @@ module.exports.useragents = {
, 'K-Meleon': {
'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:24.0) Gecko/20140105 Firefox/24.0 K-Meleon/74.0': {
windows: true
, osversion: '7'
, kMeleon: true
, version: '74.0'
, gecko: true