@arcblock/react-hooks 2.8.16 → 2.8.17

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.
package/lib/useBrowser.js CHANGED
@@ -12,10 +12,21 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
12
12
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
13
13
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
14
14
  function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
15
+ const DID_WALLET_TAG = 'ABTWallet';
16
+ function getDIDWalletVersion(userAgent) {
17
+ var _result$groups;
18
+ const reg = new RegExp("".concat(DID_WALLET_TAG, "/(?<version>[0-9.]+)"), 'g');
19
+ const result = reg.exec(userAgent);
20
+ const version = result === null || result === void 0 ? void 0 : (_result$groups = result.groups) === null || _result$groups === void 0 ? void 0 : _result$groups.version;
21
+ return version;
22
+ }
15
23
  function useBrowser() {
24
+ var _window, _window$navigator;
25
+ const userAgent = (_window = window) === null || _window === void 0 ? void 0 : (_window$navigator = _window.navigator) === null || _window$navigator === void 0 ? void 0 : _window$navigator.userAgent;
16
26
  const [browser] = (0, _react.useState)({
17
- wallet: navigator.userAgent.indexOf('ABTWallet') > -1,
18
- wechat: /MicroMessenger/i.test(navigator.userAgent),
27
+ wallet: userAgent.indexOf(DID_WALLET_TAG) > -1,
28
+ walletVersion: getDIDWalletVersion(userAgent),
29
+ wechat: /MicroMessenger/i.test(userAgent),
19
30
  mobile: _objectSpread({
20
31
  apple: {
21
32
  phone: false,
@@ -49,7 +60,7 @@ function useBrowser() {
49
60
  phone: false,
50
61
  tablet: false,
51
62
  any: false
52
- }, (0, _ismobilejs.default)(navigator.userAgent))
63
+ }, (0, _ismobilejs.default)(userAgent))
53
64
  });
54
65
  return browser;
55
66
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@arcblock/react-hooks",
3
- "version": "2.8.16",
3
+ "version": "2.8.17",
4
4
  "description": "React hooks used by arcblock products",
5
5
  "keywords": [
6
6
  "react",
@@ -45,5 +45,5 @@
45
45
  "eslint-plugin-react-hooks": "^4.6.0",
46
46
  "jest": "^28.1.3"
47
47
  },
48
- "gitHead": "dc9390c0ece7e74eb351c568ef8cb4a3d167fac3"
48
+ "gitHead": "bd7a8f9d5bfbd61bcb0f6ff57de4600d8afded7b"
49
49
  }
package/src/useBrowser.js CHANGED
@@ -1,10 +1,21 @@
1
1
  import { useState } from 'react';
2
2
  import isMobile from 'ismobilejs';
3
3
 
4
+ const DID_WALLET_TAG = 'ABTWallet';
5
+
6
+ function getDIDWalletVersion(userAgent) {
7
+ const reg = new RegExp(`${DID_WALLET_TAG}/(?<version>[0-9.]+)`, 'g');
8
+ const result = reg.exec(userAgent);
9
+ const version = result?.groups?.version;
10
+ return version;
11
+ }
12
+
4
13
  export default function useBrowser() {
14
+ const userAgent = window?.navigator?.userAgent;
5
15
  const [browser] = useState({
6
- wallet: navigator.userAgent.indexOf('ABTWallet') > -1,
7
- wechat: /MicroMessenger/i.test(navigator.userAgent),
16
+ wallet: userAgent.indexOf(DID_WALLET_TAG) > -1,
17
+ walletVersion: getDIDWalletVersion(userAgent),
18
+ wechat: /MicroMessenger/i.test(userAgent),
8
19
  mobile: {
9
20
  apple: {
10
21
  phone: false,
@@ -38,7 +49,7 @@ export default function useBrowser() {
38
49
  phone: false,
39
50
  tablet: false,
40
51
  any: false,
41
- ...isMobile(navigator.userAgent),
52
+ ...isMobile(userAgent),
42
53
  },
43
54
  });
44
55