mirror of
https://github.com/lancedikson/bowser
synced 2024-10-27 20:34:22 +00:00
Replace OS version regexps by more greedy ones
This commit is contained in:
parent
3cd9da66ae
commit
39afeb5615
@ -28,7 +28,7 @@ import {
|
|||||||
getSecondMatch
|
getSecondMatch
|
||||||
} from './utils';
|
} from './utils';
|
||||||
|
|
||||||
const commonVersionIdentifier = /version\/(\d+(\.\d+)?)/i;
|
const commonVersionIdentifier = /version\/(\d+(\.?_?\d+)+)/i;
|
||||||
const RENDERING_ENGINES_NAMES = {
|
const RENDERING_ENGINES_NAMES = {
|
||||||
blink: 'Blink',
|
blink: 'Blink',
|
||||||
webkit: 'WebKit',
|
webkit: 'WebKit',
|
||||||
@ -41,7 +41,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/opera/i],
|
test: [/opera/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:opera)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:opera)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Opera',
|
name: 'Opera',
|
||||||
@ -63,7 +63,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/SamsungBrowser/i],
|
test: [/SamsungBrowser/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:SamsungBrowser)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:SamsungBrowser)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Samsung Internet for Android',
|
name: 'Samsung Internet for Android',
|
||||||
@ -74,7 +74,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/coast/i],
|
test: [/coast/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:coast)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:coast)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Opera Coast',
|
name: 'Opera Coast',
|
||||||
@ -85,7 +85,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/yabrowser/i],
|
test: [/yabrowser/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:yabrowser)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:yabrowser)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Yandex Browser',
|
name: 'Yandex Browser',
|
||||||
@ -96,7 +96,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/ucbrowser/i],
|
test: [/ucbrowser/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:ucbrowser)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:ucbrowser)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'UC Browser',
|
name: 'UC Browser',
|
||||||
@ -107,7 +107,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/mxios/i],
|
test: [/mxios/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:mxios)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:mxios)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Maxthon',
|
name: 'Maxthon',
|
||||||
@ -118,7 +118,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/epiphany/i],
|
test: [/epiphany/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:epiphany)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:epiphany)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Epiphany',
|
name: 'Epiphany',
|
||||||
@ -129,7 +129,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/puffin/i],
|
test: [/puffin/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:puffin)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:puffin)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Puffin',
|
name: 'Puffin',
|
||||||
@ -140,7 +140,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/sleipnir/i],
|
test: [/sleipnir/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:sleipnir)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:sleipnir)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Sleipnir',
|
name: 'Sleipnir',
|
||||||
@ -151,7 +151,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/k-meleon/i],
|
test: [/k-meleon/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:k-meleon)[\s\/](\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/(?:k-meleon)[\s\/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'K-Meleon',
|
name: 'K-Meleon',
|
||||||
@ -162,7 +162,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/msie|trident/i],
|
test: [/msie|trident/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/(?:msie |rv:)(\S+)/i, ua);
|
const version = getFirstMatch(/(?:msie |rv:)(\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Internet Explorer',
|
name: 'Internet Explorer',
|
||||||
@ -173,7 +173,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/chrome.+? edge/i],
|
test: [/chrome.+? edge/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/edge\/(\S+)/i, ua);
|
const version = getFirstMatch(/edge\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Microsoft Edge',
|
name: 'Microsoft Edge',
|
||||||
@ -185,7 +185,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/vivaldi/i],
|
test: [/vivaldi/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/vivaldi\/(\S+)/i, ua);
|
const version = getFirstMatch(/vivaldi\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Vivaldi',
|
name: 'Vivaldi',
|
||||||
@ -196,7 +196,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/seamonkey/i],
|
test: [/seamonkey/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/seamonkey\/(\S+)/i, ua);
|
const version = getFirstMatch(/seamonkey\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
return {
|
return {
|
||||||
name: 'SeaMonkey',
|
name: 'SeaMonkey',
|
||||||
engine: RENDERING_ENGINES_NAMES.gecko,
|
engine: RENDERING_ENGINES_NAMES.gecko,
|
||||||
@ -207,7 +207,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/firefox|iceweasel|fxios/i],
|
test: [/firefox|iceweasel|fxios/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/(?:firefox|iceweasel|fxios)[ \/](\S+)/i, ua);
|
const version = getFirstMatch(/(?:firefox|iceweasel|fxios)[ \/](\d+(\.?_?\d+)+)/i, ua);
|
||||||
return {
|
return {
|
||||||
name: 'Firefox',
|
name: 'Firefox',
|
||||||
engine: RENDERING_ENGINES_NAMES.gecko,
|
engine: RENDERING_ENGINES_NAMES.gecko,
|
||||||
@ -218,7 +218,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/silk/i],
|
test: [/silk/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/silk\/(\S+)/i, ua);
|
const version = getFirstMatch(/silk\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
return {
|
return {
|
||||||
name: 'Amazon Silk',
|
name: 'Amazon Silk',
|
||||||
version
|
version
|
||||||
@ -228,7 +228,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/phantom/i],
|
test: [/phantom/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/phantomjs\/(\S+)/i, ua);
|
const version = getFirstMatch(/phantomjs\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'PhantomJS',
|
name: 'PhantomJS',
|
||||||
@ -239,7 +239,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/slimerjs/i],
|
test: [/slimerjs/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/slimerjs\/(\S+)/i, ua);
|
const version = getFirstMatch(/slimerjs\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'SlimerJS',
|
name: 'SlimerJS',
|
||||||
@ -250,7 +250,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/blackberry|\bbb\d+/i, /rim\stablet/i],
|
test: [/blackberry|\bbb\d+/i, /rim\stablet/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/blackberry[\d]+\/(\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/blackberry[\d]+\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'BlackBerry',
|
name: 'BlackBerry',
|
||||||
@ -261,7 +261,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/(web|hpw)os/i],
|
test: [/(web|hpw)os/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/w(?:eb)?osbrowser\/(\S+)/i, ua);
|
const version = getFirstMatch(commonVersionIdentifier, ua) || getFirstMatch(/w(?:eb)?osbrowser\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'WebOS Browser',
|
name: 'WebOS Browser',
|
||||||
@ -272,7 +272,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/bada/i],
|
test: [/bada/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/dolfin\/(\S+)/i, ua);
|
const version = getFirstMatch(/dolfin\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Bada',
|
name: 'Bada',
|
||||||
@ -283,7 +283,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/tizen/i],
|
test: [/tizen/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/(?:tizen\s?)?browser\/(\S+)/i, ua) || getFirstMatch(commonVersionIdentifier, ua);
|
const version = getFirstMatch(/(?:tizen\s?)?browser\/(\d+(\.?_?\d+)+)/i, ua) || getFirstMatch(commonVersionIdentifier, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Tizen',
|
name: 'Tizen',
|
||||||
@ -294,7 +294,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/qupzilla/i],
|
test: [/qupzilla/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/(?:qupzilla)[\s\/](\S+)/i, ua) || getFirstMatch(commonVersionIdentifier, ua);
|
const version = getFirstMatch(/(?:qupzilla)[\s\/](\d+(\.?_?\d+)+)/i, ua) || getFirstMatch(commonVersionIdentifier, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'QupZilla',
|
name: 'QupZilla',
|
||||||
@ -305,7 +305,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/chromium/i],
|
test: [/chromium/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/(?:chromium)[\s\/](\S+)/i, ua) || getFirstMatch(commonVersionIdentifier, ua);
|
const version = getFirstMatch(/(?:chromium)[\s\/](\d+(\.?_?\d+)+)/i, ua) || getFirstMatch(commonVersionIdentifier, ua);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: 'Chromium',
|
name: 'Chromium',
|
||||||
@ -316,7 +316,7 @@ const browsersList = [
|
|||||||
{
|
{
|
||||||
test: [/chrome|crios|crmo/i],
|
test: [/chrome|crios|crmo/i],
|
||||||
describe(ua) {
|
describe(ua) {
|
||||||
const version = getFirstMatch(/(?:chrome|crios|crmo)\/(\S+)/i, ua);
|
const version = getFirstMatch(/(?:chrome|crios|crmo)\/(\d+(\.?_?\d+)+)/i, ua);
|
||||||
let engine;
|
let engine;
|
||||||
if (/(apple)?webkit\/537\.36/i.test(ua)) {
|
if (/(apple)?webkit\/537\.36/i.test(ua)) {
|
||||||
engine = RENDERING_ENGINES_NAMES.blink;
|
engine = RENDERING_ENGINES_NAMES.blink;
|
||||||
|
Loading…
Reference in New Issue
Block a user