native-fn 1.0.73 → 1.0.75

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (80) hide show
  1. package/dist/index.d.ts +5 -5
  2. package/dist/native.cjs +1 -1
  3. package/dist/native.min.cjs +1 -1
  4. package/dist/native.min.mjs +1 -1
  5. package/dist/native.mjs +1 -1
  6. package/dist/native.umd.js +1 -1
  7. package/dist/native.umd.min.js +1 -1
  8. package/dist/plugin/app/index.cjs +357 -178
  9. package/dist/plugin/app/index.min.cjs +1 -1
  10. package/dist/plugin/app/index.min.mjs +1 -1
  11. package/dist/plugin/app/index.mjs +357 -178
  12. package/dist/plugin/app/index.umd.js +357 -178
  13. package/dist/plugin/app/index.umd.min.js +1 -1
  14. package/dist/plugin/app/src/plugin/platform/constants/index.d.ts +1 -1
  15. package/dist/plugin/app/src/plugin/platform/cores/index.d.ts +12 -0
  16. package/dist/plugin/app/src/plugin/platform/types/platform.d.ts +16 -6
  17. package/dist/plugin/app/src/types/native.d.ts +5 -5
  18. package/dist/plugin/appearance/index.cjs +346 -167
  19. package/dist/plugin/appearance/index.min.cjs +1 -1
  20. package/dist/plugin/appearance/index.min.mjs +1 -1
  21. package/dist/plugin/appearance/index.mjs +346 -167
  22. package/dist/plugin/appearance/index.umd.js +346 -167
  23. package/dist/plugin/appearance/index.umd.min.js +1 -1
  24. package/dist/plugin/appearance/src/plugin/platform/constants/index.d.ts +1 -1
  25. package/dist/plugin/appearance/src/plugin/platform/cores/index.d.ts +12 -0
  26. package/dist/plugin/appearance/src/plugin/platform/types/platform.d.ts +16 -6
  27. package/dist/plugin/appearance/src/types/native.d.ts +5 -5
  28. package/dist/plugin/camera/index.cjs +2 -2
  29. package/dist/plugin/camera/index.min.cjs +1 -1
  30. package/dist/plugin/camera/index.min.mjs +1 -1
  31. package/dist/plugin/camera/index.mjs +2 -2
  32. package/dist/plugin/camera/index.umd.js +2 -2
  33. package/dist/plugin/camera/index.umd.min.js +1 -1
  34. package/dist/plugin/camera/src/plugin/platform/constants/index.d.ts +1 -1
  35. package/dist/plugin/clipboard/index.cjs +341 -162
  36. package/dist/plugin/clipboard/index.min.cjs +1 -1
  37. package/dist/plugin/clipboard/index.min.mjs +1 -1
  38. package/dist/plugin/clipboard/index.mjs +341 -162
  39. package/dist/plugin/clipboard/index.umd.js +341 -162
  40. package/dist/plugin/clipboard/index.umd.min.js +1 -1
  41. package/dist/plugin/clipboard/src/plugin/platform/constants/index.d.ts +1 -1
  42. package/dist/plugin/clipboard/src/plugin/platform/cores/index.d.ts +12 -0
  43. package/dist/plugin/clipboard/src/plugin/platform/types/platform.d.ts +16 -6
  44. package/dist/plugin/clipboard/src/types/native.d.ts +5 -5
  45. package/dist/plugin/fullscreen/index.cjs +350 -171
  46. package/dist/plugin/fullscreen/index.min.cjs +1 -1
  47. package/dist/plugin/fullscreen/index.min.mjs +1 -1
  48. package/dist/plugin/fullscreen/index.mjs +350 -171
  49. package/dist/plugin/fullscreen/index.umd.js +350 -171
  50. package/dist/plugin/fullscreen/index.umd.min.js +1 -1
  51. package/dist/plugin/fullscreen/src/plugin/platform/constants/index.d.ts +1 -1
  52. package/dist/plugin/fullscreen/src/plugin/platform/cores/index.d.ts +12 -0
  53. package/dist/plugin/fullscreen/src/plugin/platform/types/platform.d.ts +16 -6
  54. package/dist/plugin/fullscreen/src/types/native.d.ts +5 -5
  55. package/dist/plugin/platform/index.cjs +341 -162
  56. package/dist/plugin/platform/index.d.ts +18 -8
  57. package/dist/plugin/platform/index.min.cjs +1 -1
  58. package/dist/plugin/platform/index.min.mjs +1 -1
  59. package/dist/plugin/platform/index.mjs +341 -162
  60. package/dist/plugin/platform/index.umd.js +341 -162
  61. package/dist/plugin/platform/index.umd.min.js +1 -1
  62. package/dist/plugin/platform/src/plugin/platform/constants/index.d.ts +1 -1
  63. package/dist/plugin/platform/src/plugin/platform/cores/index.d.ts +12 -0
  64. package/dist/plugin/platform/src/plugin/platform/types/platform.d.ts +16 -6
  65. package/dist/plugin/platform/src/types/native.d.ts +5 -5
  66. package/dist/plugin/theme/index.cjs +341 -162
  67. package/dist/plugin/theme/index.min.cjs +1 -1
  68. package/dist/plugin/theme/index.min.mjs +1 -1
  69. package/dist/plugin/theme/index.mjs +341 -162
  70. package/dist/plugin/theme/index.umd.js +341 -162
  71. package/dist/plugin/theme/index.umd.min.js +1 -1
  72. package/dist/plugin/theme/src/plugin/platform/constants/index.d.ts +1 -1
  73. package/dist/plugin/theme/src/plugin/platform/cores/index.d.ts +12 -0
  74. package/dist/plugin/theme/src/plugin/platform/types/platform.d.ts +16 -6
  75. package/dist/plugin/theme/src/types/native.d.ts +5 -5
  76. package/dist/src/plugin/platform/constants/index.d.ts +1 -1
  77. package/dist/src/plugin/platform/cores/index.d.ts +12 -0
  78. package/dist/src/plugin/platform/types/platform.d.ts +16 -6
  79. package/dist/src/types/native.d.ts +5 -5
  80. package/package.json +1 -1
@@ -41,7 +41,7 @@ var Browsers;
41
41
  })(Browsers || (Browsers = {}));
42
42
  var CrossPlatformFramework;
43
43
  (function (CrossPlatformFramework) {
44
- CrossPlatformFramework["NotACrossPlatformFramework"] = "NotACrossPlatformFramework";
44
+ CrossPlatformFramework["Unknown"] = "Unknown";
45
45
  CrossPlatformFramework["ReactNative"] = "ReactNative";
46
46
  CrossPlatformFramework["Electron"] = "Electron";
47
47
  CrossPlatformFramework["Cordova"] = "Cordova";
@@ -72,21 +72,43 @@ function compareVersion(lhs, rhs) {
72
72
  }
73
73
 
74
74
  var Platform = {
75
- device: Devices.Unknown,
76
- os: OS.Unknown,
77
- engine: Engines.Unknown,
78
- browser: Browsers.Unknown,
79
- crossPlatformFramework: CrossPlatformFramework.NotACrossPlatformFramework,
80
- osVersion: '',
81
- engineVersion: '',
82
- browserVersion: '',
83
- renderer: getRenderer(),
75
+ os: { name: OS.Unknown, version: '' },
76
+ engine: { name: Engines.Unknown, version: '' },
77
+ browser: { name: Browsers.Unknown, version: '' },
78
+ crossPlatformFramework: CrossPlatformFramework.Unknown,
84
79
  userAgent: USER_AGENT,
85
- isNode: typeof globalThis.process !== 'undefined' && typeof globalThis.process.versions !== 'undefined' && globalThis.process.versions.node !== undefined,
86
- isMobile: false,
87
- isDesktop: false,
88
- isStandalone: false,
89
- isWebview: /; ?wv|applewebkit(?!.*safari)/i.test(USER_AGENT),
80
+ get network() {
81
+ return getNetwork();
82
+ },
83
+ get device() {
84
+ if (this.os.name === OS.iOS || this.os.name === OS.Android)
85
+ return Devices.Mobile;
86
+ if (this.os.name === OS.Windows || this.os.name === OS.MacOS)
87
+ return Devices.Desktop;
88
+ return Devices.Unknown;
89
+ },
90
+ get renderer() {
91
+ return getRenderer();
92
+ },
93
+ get isMobile() {
94
+ return this.device === Devices.Mobile;
95
+ },
96
+ get isDesktop() {
97
+ return this.device === Devices.Desktop;
98
+ },
99
+ get isWebview() {
100
+ return /; ?wv|applewebkit(?!.*safari)/i.test(this.userAgent);
101
+ },
102
+ get isNode() {
103
+ return typeof globalThis.process !== 'undefined' && typeof globalThis.process.versions !== 'undefined' && globalThis.process.versions.node !== undefined;
104
+ },
105
+ get isStandalone() {
106
+ if (this.os.name === OS.iOS)
107
+ return 'standalone' in globalThis.navigator && !!globalThis.navigator.standalone;
108
+ if (!('matchMedia' in globalThis))
109
+ return false;
110
+ return globalThis.matchMedia('(display-mode: standalone)').matches;
111
+ },
90
112
  };
91
113
  var OS_RESOLVER_MAP = [
92
114
  [/windows nt (6\.[23]); arm/i, OS.Windows, resolveWindowsVersion],
@@ -146,6 +168,14 @@ var BROWSER_RESOLVER_MAP = [
146
168
  [/mobile vr; rv:([\w.]+)\).+firefox/i, Browsers.Firefox],
147
169
  [/firefox\/([\w.]+)/i, Browsers.Firefox],
148
170
  ];
171
+ var HIGH_ENTROPY_BRAND_NAME_MAP = {
172
+ 'Google Chrome': 'Chrome',
173
+ 'Microsoft Edge': 'Edge',
174
+ 'Microsoft Edge WebView2': 'Edge WebView2',
175
+ 'Android WebView': 'Chrome WebView',
176
+ 'HeadlessChrome': 'Chrome Headless',
177
+ 'OperaMobile': 'Opera Mobi',
178
+ };
149
179
  function resolveWindowsVersion(string) {
150
180
  if (string === undefined)
151
181
  return '';
@@ -320,6 +350,33 @@ function normalizeBrand(entry) {
320
350
  return { brand: entry, version: '' };
321
351
  return { brand: entry.brand, version: entry.version };
322
352
  }
353
+ function getSemanticVersion(string) {
354
+ var parts = string.split('.');
355
+ return {
356
+ major: parseInt(parts[0] || '0'),
357
+ minor: parseInt(parts[1] || '0'),
358
+ build: parseInt(parts[2] || '0')
359
+ };
360
+ }
361
+ function parseOSFromCordova() {
362
+ Platform.crossPlatformFramework = CrossPlatformFramework.Cordova;
363
+ if (typeof globalThis.device !== 'undefined') {
364
+ switch (globalThis.device.platform) {
365
+ case 'Android':
366
+ Platform.os = {
367
+ name: OS.Android,
368
+ version: globalThis.device.version,
369
+ };
370
+ break;
371
+ case 'iOS':
372
+ Platform.os = {
373
+ name: OS.iOS,
374
+ version: globalThis.device.version,
375
+ };
376
+ break;
377
+ }
378
+ }
379
+ }
323
380
  function getRenderer() {
324
381
  if (typeof globalThis.document === 'undefined')
325
382
  return '';
@@ -340,171 +397,293 @@ function getRenderer() {
340
397
  return '';
341
398
  }
342
399
  }
343
- function getIsStandalone(os) {
344
- if (!('matchMedia' in globalThis))
345
- return false;
346
- if (os === OS.iOS)
347
- return 'standalone' in navigator && !!navigator.standalone;
348
- return globalThis.matchMedia('(display-mode: standalone)').matches;
349
- }
350
- function getSemanticVersion(string) {
351
- var parts = string.split('.');
352
- return {
353
- major: parseInt(parts[0] || '0'),
354
- minor: parseInt(parts[1] || '0'),
355
- build: parseInt(parts[2] || '0')
400
+ function getNetwork() {
401
+ var network = {
402
+ isOnline: null,
403
+ effectiveType: null,
404
+ type: null,
405
+ downlink: null,
406
+ rtt: null,
407
+ saveData: null,
356
408
  };
357
- }
358
- if ((typeof globalThis.process !== 'undefined' && typeof globalThis.process.versions !== 'undefined' && globalThis.process.versions.electron !== undefined) || (/ electron\//i.test(USER_AGENT))) {
359
- Platform.crossPlatformFramework = CrossPlatformFramework.Electron;
360
- }
361
- if (typeof globalThis.navigator !== 'undefined' && globalThis.navigator.product === 'ReactNative') {
362
- Platform.crossPlatformFramework = CrossPlatformFramework.ReactNative;
363
- }
364
- for (var i = 0; i < OS_RESOLVER_MAP.length; i++) {
365
- var map = OS_RESOLVER_MAP[i];
366
- var regexp = map[0];
367
- var os = map[1];
368
- var resolver = map[2];
369
- var matched = Platform.userAgent.match(regexp);
370
- if (matched !== null) {
371
- Platform.os = os;
372
- Platform.osVersion = resolveVersion(matched[1], resolver);
373
- break;
409
+ if (typeof globalThis.navigator !== 'undefined') {
410
+ if (typeof globalThis.navigator.onLine !== 'undefined')
411
+ network.isOnline = globalThis.navigator.onLine;
412
+ var connection = globalThis.navigator.connection || globalThis.navigator.mozConnection || globalThis.navigator.webkitConnection;
413
+ if (typeof connection !== 'undefined') {
414
+ if (typeof connection.effectiveType !== 'undefined')
415
+ network.effectiveType = connection.effectiveType;
416
+ if (typeof connection.type !== 'undefined')
417
+ network.type = connection.type;
418
+ if (typeof connection.downlink !== 'undefined')
419
+ network.downlink = connection.downlink;
420
+ if (typeof connection.rtt !== 'undefined')
421
+ network.rtt = connection.rtt;
422
+ if (typeof connection.saveData !== 'undefined')
423
+ network.saveData = connection.saveData;
424
+ }
374
425
  }
375
- }
376
- if (Platform.os === OS.iOS && compareVersion(Platform.osVersion, '18.6') === 0) {
377
- var version = /\) Version\/([\d.]+)/.exec(Platform.userAgent);
378
- if (version !== null && parseInt(version[1].substring(0, 2), 10) >= 26)
379
- Platform.osVersion = version[1];
380
- }
381
- for (var i = 0; i < ENGINE_RESOLVER_MAP.length; i++) {
382
- var map = ENGINE_RESOLVER_MAP[i];
383
- var regexp = map[0];
384
- var engine = map[1];
385
- var resolver = map[2];
386
- var matched = Platform.userAgent.match(regexp);
387
- if (matched !== null) {
388
- Platform.engine = engine;
389
- Platform.engineVersion = resolveVersion(matched[1], resolver);
390
- break;
426
+ if (Platform.isNode) {
427
+ try {
428
+ var os = require('os');
429
+ var networkInterfaces = os.networkInterfaces();
430
+ var networkInterfaceNames = Object.keys(networkInterfaces);
431
+ for (var i = 0; i < networkInterfaceNames.length; i++) {
432
+ var name_1 = networkInterfaceNames[i];
433
+ var networkInterface = networkInterfaces[name_1];
434
+ for (var j = 0; j < networkInterface.length; j++) {
435
+ var address = networkInterface[j];
436
+ if (!address.internal && address.family === 'IPv4')
437
+ network.isOnline = true;
438
+ }
439
+ if (network.isOnline)
440
+ break;
441
+ }
442
+ }
443
+ catch (_) {
444
+ }
445
+ try {
446
+ var childProcess = require('child_process');
447
+ if (Platform.os.name === OS.Windows) {
448
+ try {
449
+ var output = childProcess.execSync('netsh wlan show interfaces', { encoding: 'utf8', timeout: 5000 });
450
+ if (output.includes('State') && output.includes('connected'))
451
+ network.type = 'wifi';
452
+ }
453
+ catch (_) {
454
+ }
455
+ if (network.type === null) {
456
+ try {
457
+ var output = childProcess.execSync('ipconfig', { encoding: 'utf8', timeout: 5000 });
458
+ if (output.includes('Ethernet adapter'))
459
+ network.type = 'ethernet';
460
+ }
461
+ catch (_) {
462
+ }
463
+ }
464
+ if (network.type === null)
465
+ network.type = 'other';
466
+ }
467
+ else if (Platform.os.name === OS.MacOS) {
468
+ try {
469
+ var output = childProcess.execSync('networksetup -listallhardwareports', { encoding: 'utf8', timeout: 5000 });
470
+ var activeInterface = childProcess.execSync('route -n get default | grep interface', { encoding: 'utf8', timeout: 5000 });
471
+ if (activeInterface.includes('en0') && output.includes('Wi-Fi'))
472
+ network.type = 'wifi';
473
+ else if (activeInterface.includes('en') || output.includes('Ethernet'))
474
+ network.type = 'ethernet';
475
+ else
476
+ network.type = 'other';
477
+ }
478
+ catch (_) {
479
+ network.type = 'other';
480
+ }
481
+ }
482
+ }
483
+ catch (_) {
484
+ }
391
485
  }
486
+ return network;
392
487
  }
393
- for (var i = 0; i < BROWSER_RESOLVER_MAP.length; i++) {
394
- var map = BROWSER_RESOLVER_MAP[i];
395
- var regexp = map[0];
396
- var browser = map[1];
397
- var resolver = map[2];
398
- var matched = Platform.userAgent.match(regexp);
399
- if (matched !== null) {
400
- Platform.browser = browser;
401
- Platform.browserVersion = resolveVersion(matched[1], resolver);
402
- break;
403
- }
488
+ function canUseHighEntropyValues(navigator) {
489
+ return typeof globalThis.navigator !== 'undefined' && typeof navigator.userAgentData !== 'undefined' && typeof navigator.userAgentData.getHighEntropyValues !== 'undefined';
404
490
  }
405
- if (Platform.crossPlatformFramework === CrossPlatformFramework.ReactNative) {
406
- try {
407
- var reactNative = require('react-native');
408
- var platform = reactNative.Platform;
409
- var os = platform.OS;
410
- var release = '' + platform.Version;
411
- var version = getSemanticVersion(release);
412
- switch (os) {
413
- case 'android':
414
- Platform.os = OS.Android;
415
- Platform.osVersion = resolveSemanticAndroidVersion(version, release);
416
- break;
417
- case 'ios':
418
- Platform.os = OS.iOS;
419
- Platform.osVersion = release;
420
- break;
421
- case 'windows':
422
- Platform.os = OS.Windows;
423
- Platform.osVersion = resolveSemanticWindowsVersion(version, release);
424
- break;
425
- case 'macos':
426
- Platform.os = OS.MacOS;
427
- Platform.osVersion = release;
428
- break;
491
+ function init() {
492
+ if ((typeof globalThis.process !== 'undefined' && typeof globalThis.process.versions !== 'undefined' && globalThis.process.versions.electron !== undefined) || (/ electron\//i.test(USER_AGENT)))
493
+ Platform.crossPlatformFramework = CrossPlatformFramework.Electron;
494
+ if (typeof globalThis.navigator !== 'undefined' && globalThis.navigator.product === 'ReactNative')
495
+ Platform.crossPlatformFramework = CrossPlatformFramework.ReactNative;
496
+ for (var i = 0; i < OS_RESOLVER_MAP.length; i++) {
497
+ var map = OS_RESOLVER_MAP[i];
498
+ var regexp = map[0];
499
+ var os = map[1];
500
+ var resolver = map[2];
501
+ var matched = Platform.userAgent.match(regexp);
502
+ if (matched !== null) {
503
+ Platform.os = {
504
+ name: os,
505
+ version: resolveVersion(matched[1], resolver),
506
+ };
507
+ break;
429
508
  }
430
509
  }
431
- catch (_) {
510
+ if (Platform.os.name === OS.iOS && compareVersion(Platform.os.version, '18.6') === 0) {
511
+ var version = /\) Version\/([\d.]+)/.exec(Platform.userAgent);
512
+ if (version !== null && parseInt(version[1].substring(0, 2), 10) >= 26)
513
+ Platform.os.version = version[1];
432
514
  }
433
- }
434
- if (Platform.isNode) {
435
- try {
436
- var os = require('os');
437
- var platform = os.platform();
438
- var release = os.release();
439
- var version = getSemanticVersion(release);
440
- switch (platform) {
441
- case 'win32':
442
- Platform.os = OS.Windows;
443
- Platform.osVersion = resolveSemanticWindowsVersion(version, release);
444
- break;
445
- case 'darwin':
446
- Platform.os = OS.MacOS;
447
- Platform.osVersion = resolveSemanticDarwinVersion(version, release);
448
- break;
449
- case 'android':
450
- Platform.os = OS.Android;
451
- Platform.osVersion = release;
452
- break;
453
- case 'linux':
454
- if (/android/i.test(release)) {
455
- Platform.os = OS.Android;
456
- Platform.osVersion = release;
457
- }
458
- break;
515
+ for (var i = 0; i < ENGINE_RESOLVER_MAP.length; i++) {
516
+ var map = ENGINE_RESOLVER_MAP[i];
517
+ var regexp = map[0];
518
+ var engine = map[1];
519
+ var resolver = map[2];
520
+ var matched = Platform.userAgent.match(regexp);
521
+ if (matched !== null) {
522
+ Platform.engine = {
523
+ name: engine,
524
+ version: resolveVersion(matched[1], resolver),
525
+ };
526
+ break;
459
527
  }
460
528
  }
461
- catch (_) {
529
+ for (var i = 0; i < BROWSER_RESOLVER_MAP.length; i++) {
530
+ var map = BROWSER_RESOLVER_MAP[i];
531
+ var regexp = map[0];
532
+ var browser = map[1];
533
+ var resolver = map[2];
534
+ var matched = Platform.userAgent.match(regexp);
535
+ if (matched !== null) {
536
+ Platform.browser = {
537
+ name: browser,
538
+ version: resolveVersion(matched[1], resolver),
539
+ };
540
+ break;
541
+ }
462
542
  }
463
- }
464
- if (typeof globalThis.document !== 'undefined') {
465
- globalThis.document.addEventListener("deviceready", function () {
466
- Platform.crossPlatformFramework = CrossPlatformFramework.Cordova;
467
- if (Platform.os === OS.Unknown && typeof globalThis.device !== 'undefined') {
468
- switch (globalThis.device.platform) {
469
- case 'Android':
470
- Platform.os = OS.Android;
543
+ if (Platform.crossPlatformFramework === CrossPlatformFramework.ReactNative) {
544
+ try {
545
+ var reactNative = require('react-native');
546
+ var platform = reactNative.Platform;
547
+ var os = platform.OS;
548
+ var release = '' + platform.Version;
549
+ var version = getSemanticVersion(release);
550
+ switch (os) {
551
+ case 'android':
552
+ Platform.os = {
553
+ name: OS.Android,
554
+ version: resolveSemanticAndroidVersion(version, release),
555
+ };
556
+ break;
557
+ case 'ios':
558
+ Platform.os = {
559
+ name: OS.iOS,
560
+ version: release,
561
+ };
471
562
  break;
472
- case 'iOS':
473
- Platform.os = OS.iOS;
563
+ case 'windows':
564
+ Platform.os = {
565
+ name: OS.Windows,
566
+ version: resolveSemanticWindowsVersion(version, release),
567
+ };
568
+ break;
569
+ case 'macos':
570
+ Platform.os = {
571
+ name: OS.MacOS,
572
+ version: release,
573
+ };
474
574
  break;
475
575
  }
476
- Platform.osVersion = globalThis.device.version;
477
576
  }
478
- }, false);
479
- }
480
- if (navigator.userAgentData !== undefined && navigator.userAgentData.getHighEntropyValues !== undefined) {
481
- navigator
482
- .userAgentData
483
- .getHighEntropyValues(['brands', 'fullVersionList', 'mobile', 'model', 'platform', 'platformVersion', 'architecture', 'formFactors', 'bitness', 'uaFullVersion', 'wow64'])
484
- .then(function (result) {
485
- var brands = result.fullVersionList || result.brands || [];
486
- var platformVersion = result.platformVersion;
487
- for (var i = 0; i < brands.length; i++) {
488
- var brand = normalizeBrand(brands[i]);
489
- var brandName = brand.brand;
490
- var brandVersion = brand.version;
491
- if (/not.a.brand/i.test(brandName))
492
- continue;
493
- if (brandName === "Chromium")
494
- Platform.engineVersion = brandVersion;
577
+ catch (_) {
578
+ }
579
+ finally {
580
+ }
581
+ }
582
+ if (Platform.isNode) {
583
+ try {
584
+ var os = require('os');
585
+ var platform = os.platform();
586
+ var release = os.release();
587
+ var version = getSemanticVersion(release);
588
+ switch (platform) {
589
+ case 'win32':
590
+ Platform.os = {
591
+ name: OS.Windows,
592
+ version: resolveSemanticWindowsVersion(version, release),
593
+ };
594
+ break;
595
+ case 'darwin':
596
+ Platform.os = {
597
+ name: OS.MacOS,
598
+ version: resolveSemanticDarwinVersion(version, release),
599
+ };
600
+ break;
601
+ case 'android':
602
+ Platform.os = {
603
+ name: OS.Android,
604
+ version: release,
605
+ };
606
+ break;
607
+ case 'linux':
608
+ if (/android/i.test(release)) {
609
+ Platform.os = {
610
+ name: OS.Android,
611
+ version: release,
612
+ };
613
+ }
614
+ break;
615
+ }
495
616
  }
496
- if (typeof platformVersion === 'string') {
497
- if (Platform.os === OS.Windows && parseInt(platformVersion.replace(/[^\d.]/g, '').split('.')[0], 10) >= 13)
498
- Platform.osVersion = '11';
499
- else
500
- Platform.osVersion = platformVersion;
617
+ catch (_) {
501
618
  }
502
- });
619
+ finally {
620
+ }
621
+ }
622
+ if (typeof globalThis.document !== 'undefined') {
623
+ if (typeof globalThis.device !== 'undefined') {
624
+ parseOSFromCordova();
625
+ }
626
+ else {
627
+ globalThis.document.addEventListener("deviceready", parseOSFromCordova, false);
628
+ }
629
+ }
630
+ if (canUseHighEntropyValues(globalThis.navigator)) {
631
+ globalThis
632
+ .navigator
633
+ .userAgentData
634
+ .getHighEntropyValues(['brands', 'fullVersionList', 'mobile', 'model', 'platform', 'platformVersion', 'architecture', 'formFactors', 'bitness', 'uaFullVersion', 'wow64'])
635
+ .then(function (result) {
636
+ var brands = result.fullVersionList || result.brands || [];
637
+ var platformVersion = result.platformVersion;
638
+ var platform = result.platform;
639
+ var browserName = Platform.browser.name;
640
+ var prevBrandName = null;
641
+ for (var i = 0; i < brands.length; i++) {
642
+ var brand = normalizeBrand(brands[i]);
643
+ var brandVersion = brand.version;
644
+ var brandName = brand.brand;
645
+ if (/not.a.brand/i.test(brandName))
646
+ continue;
647
+ if (prevBrandName === null || (/Chrom/.test(prevBrandName) && brandName !== 'Chromium') || (prevBrandName === 'Edge' && /WebView2/.test(brandName))) {
648
+ brandName = HIGH_ENTROPY_BRAND_NAME_MAP[brandName] || brandName;
649
+ prevBrandName = browserName;
650
+ if (prevBrandName === null || /Chrom/.test(prevBrandName) || !/Chrom/.test(brandName)) {
651
+ browserName = brandName;
652
+ if (browserName === 'Chrome' || browserName === 'Chrome WebView' || browserName === 'Chrome Headless')
653
+ Platform.browser.name = Browsers.Chrome;
654
+ else if (browserName === 'Edge' || browserName === 'Edge WebView2')
655
+ Platform.browser.name = Browsers.Edge;
656
+ else if (browserName === 'Opera Mobi')
657
+ Platform.browser.name = Browsers.Opera;
658
+ Platform.browser.version = brandVersion;
659
+ }
660
+ prevBrandName = brandName;
661
+ }
662
+ if (brandName === 'Chromium')
663
+ Platform.engine.version = brandVersion;
664
+ }
665
+ if (typeof platformVersion === 'string') {
666
+ if (Platform.os.name === OS.Windows)
667
+ Platform.os.version = parseInt(platformVersion.split('.')[0], 10) >= 13 ? '11' : '10';
668
+ else
669
+ Platform.os.version = platformVersion;
670
+ }
671
+ if (typeof platform === 'string') {
672
+ if (/android/i.test(platform))
673
+ Platform.os.name = OS.Android;
674
+ else if (/ios|iphone|ipad/i.test(platform))
675
+ Platform.os.name = OS.iOS;
676
+ else if (/windows|win32/i.test(platform))
677
+ Platform.os.name = OS.Windows;
678
+ else if (/macos|macintel/i.test(platform))
679
+ Platform.os.name = OS.MacOS;
680
+ }
681
+ if (result.mobile === true)
682
+ Platform.device = Devices.Mobile;
683
+ });
684
+ }
503
685
  }
504
- Platform.device = Platform.os === OS.iOS || Platform.os === OS.Android ? Devices.Mobile : Platform.os === OS.Windows || Platform.os === OS.MacOS ? Devices.Desktop : Devices.Unknown;
505
- Platform.isMobile = Platform.device === Devices.Mobile;
506
- Platform.isDesktop = Platform.device === Devices.Desktop;
507
- Platform.isStandalone = getIsStandalone(Platform.os);
686
+ init();
508
687
 
509
688
  var NativePlatformPlugin = {
510
689
  installed: false,
@@ -42,21 +42,19 @@ declare enum Browsers {
42
42
  SamsungInternet = "SamsungInternet"
43
43
  }
44
44
  declare enum CrossPlatformFramework {
45
- NotACrossPlatformFramework = "NotACrossPlatformFramework",
45
+ Unknown = "Unknown",
46
46
  ReactNative = "ReactNative",
47
47
  Electron = "Electron",
48
48
  Cordova = "Cordova"
49
49
  }
50
50
 
51
51
  declare interface PlatformInstance {
52
- os: OS;
52
+ os: NameVersionPair<OS>;
53
+ engine: NameVersionPair<Engines>;
54
+ browser: NameVersionPair<Browsers>;
53
55
  device: Devices;
54
- engine: Engines;
55
- browser: Browsers;
56
56
  crossPlatformFramework: CrossPlatformFramework;
57
- osVersion: string;
58
- engineVersion: string;
59
- browserVersion: string;
57
+ network: Network;
60
58
  renderer: string;
61
59
  userAgent: string;
62
60
  isNode: boolean;
@@ -65,6 +63,18 @@ declare interface PlatformInstance {
65
63
  isDesktop: boolean;
66
64
  isWebview: boolean;
67
65
  }
66
+ declare interface NameVersionPair<T> {
67
+ name: T;
68
+ version: string;
69
+ }
70
+ declare interface Network {
71
+ isOnline: boolean | null;
72
+ effectiveType: 'slow-2g' | '2g' | '3g' | '4g' | null;
73
+ type: 'bluetooth' | 'cellular' | 'ethernet' | 'none' | 'wifi' | 'wimax' | 'other' | null;
74
+ downlink: number | null;
75
+ rtt: number | null;
76
+ saveData: boolean | null;
77
+ }
68
78
 
69
79
  declare module 'native-fn' {
70
80
  interface NativePlugins {
@@ -85,4 +95,4 @@ declare const NativePlatformPlugin: NativePlugin<'Platform', PlatformInstance, {
85
95
  }, {}>;
86
96
 
87
97
  export { NativePlatformPlugin as default };
88
- export type { PlatformInstance };
98
+ export type { NameVersionPair, Network, PlatformInstance };