@haluo/util 1.0.29 → 1.0.31

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.
@@ -20,9 +20,16 @@ function injectJsError(data) {
20
20
  if (data === void 0) { data = {}; }
21
21
  window.addEventListener('error', function (e) {
22
22
  if (e.target && (e.target.src || e.target.href)) {
23
- tracker_1.default.send(__assign({ kind: 'stability', type: 'error', title: 'resourceError', filename: e.target.src || e.target.href, tagName: e.target.tagName, reason: e.target.src || e.target.href }, data
24
- // selector: lastEvent ? get
25
- ));
23
+ // track.send({
24
+ // kind: 'stability',
25
+ // type: 'error',
26
+ // title: 'resourceError',
27
+ // filename: e.target.src || e.target.href,
28
+ // tagName: e.target.tagName,
29
+ // reason: e.target.src || e.target.href,
30
+ // ...data
31
+ // // selector: lastEvent ? get
32
+ // })
26
33
  return;
27
34
  }
28
35
  tracker_1.default.send(__assign({ kind: 'stability', type: 'error', title: 'jsError', message: e.message, filename: e.filename, position: e.lineno + ":" + e.colno, reason: e.error.stack }, data
@@ -31,7 +31,9 @@ function injectXHR(data) {
31
31
  var handler = function (type) { return function (event) {
32
32
  if (_this.logData.url.indexOf('app/collect/original/info/report/v2') > -1)
33
33
  return;
34
- if (type !== 'error')
34
+ // status = 0 是在跨域与404的情况下
35
+ // 当前都是在readyState为4(请求已完成)的情况下,进行处理
36
+ if (type !== 'error' || _this.status === 0)
35
37
  return;
36
38
  var duration = Date.now() - startTime_1;
37
39
  var status = _this.status;
@@ -11,8 +11,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
11
11
  return (mod && mod.__esModule) ? mod : { "default": mod };
12
12
  };
13
13
  Object.defineProperty(exports, "__esModule", { value: true });
14
- var raven_js_1 = __importDefault(require("raven-js"));
15
- // import RavenVue from 'raven-js/plugins/vue';
14
+ var browser_1 = __importDefault(require("@sentry/browser"));
16
15
  var Report = /** @class */ (function () {
17
16
  function Report(Vue, options) {
18
17
  if (options === void 0) { options = {}; }
@@ -36,9 +35,9 @@ var Report = /** @class */ (function () {
36
35
  // }).addPlugin(RavenVue, this.Vue).install();
37
36
  // raven内置了vue插件,会通过vue.config.errorHandler来捕获vue组件内错误并上报sentry服务
38
37
  // 记录用户信息
39
- raven_js_1.default.setUserContext({ user: this.options.user || '' });
38
+ browser_1.default.setUser({ user: this.options.user || '' });
40
39
  // 设置全局tag标签
41
- raven_js_1.default.setTagsContext({ environment: this.options.env || '' });
40
+ browser_1.default.setTag('environment', this.options.env || '');
42
41
  }
43
42
  };
44
43
  /**
@@ -52,22 +51,20 @@ var Report = /** @class */ (function () {
52
51
  if (type === void 0) { type = 'error'; }
53
52
  if (options === void 0) { options = {}; }
54
53
  // 添加面包屑
55
- raven_js_1.default.captureBreadcrumb({
54
+ browser_1.default.addBreadcrumb({
56
55
  message: data,
57
56
  category: 'manual message',
58
57
  });
59
58
  // 异常上报
60
59
  if (data instanceof Error) {
61
- raven_js_1.default.captureException(data, {
60
+ browser_1.default.captureException(data, {
62
61
  level: type,
63
- logger: 'manual exception',
64
62
  tags: { options: options },
65
63
  });
66
64
  }
67
65
  else {
68
- raven_js_1.default.captureException('error', {
66
+ browser_1.default.captureException('error', {
69
67
  level: type,
70
- logger: 'manual data',
71
68
  extra: {
72
69
  data: data,
73
70
  options: this.options,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@haluo/util",
3
- "version": "1.0.29",
3
+ "version": "1.0.31",
4
4
  "main": "./dist/index.js",
5
5
  "author": "<wanghui@jddmoto.com>",
6
6
  "description": "哈罗摩托工具库",
@@ -26,8 +26,9 @@
26
26
  "@haluo/util"
27
27
  ],
28
28
  "dependencies": {
29
+ "@sentry/browser": "^7.31.1",
29
30
  "@types/jest": "^26.0.24",
30
- "axios": "^0.19.2",
31
+ "axios": "^1.2.3",
31
32
  "clipboard-copy": "^4.0.1",
32
33
  "jest": "^27.0.6",
33
34
  "raven-js": "^3.27.2",
@@ -2,16 +2,16 @@ import track from '../utils/tracker'
2
2
  export function injectJsError (data:any={}) {
3
3
  window.addEventListener('error', (e: any) => {
4
4
  if (e.target && (e.target.src || e.target.href)) {
5
- track.send({
6
- kind: 'stability',
7
- type: 'error',
8
- title: 'resourceError',
9
- filename: e.target.src || e.target.href,
10
- tagName: e.target.tagName,
11
- reason: e.target.src || e.target.href,
12
- ...data
13
- // selector: lastEvent ? get
14
- })
5
+ // track.send({
6
+ // kind: 'stability',
7
+ // type: 'error',
8
+ // title: 'resourceError',
9
+ // filename: e.target.src || e.target.href,
10
+ // tagName: e.target.tagName,
11
+ // reason: e.target.src || e.target.href,
12
+ // ...data
13
+ // // selector: lastEvent ? get
14
+ // })
15
15
  return
16
16
  }
17
17
  track.send({
@@ -13,7 +13,9 @@ export default function injectXHR(data:any={}){
13
13
  const startTime = Date.now()
14
14
  const handler = (type:string) => (event:any) => {
15
15
  if(this.logData.url.indexOf('app/collect/original/info/report/v2') > -1 ) return
16
- if(type !== 'error') return
16
+ // status = 0 是在跨域与404的情况下
17
+ // 当前都是在readyState为4(请求已完成)的情况下,进行处理
18
+ if(type !== 'error' || this.status === 0) return
17
19
  let duration = Date.now() - startTime
18
20
  let status = this.status
19
21
  let statusText = this.statusText
@@ -8,8 +8,7 @@
8
8
  */
9
9
  'use strict'
10
10
 
11
- import Raven from 'raven-js';
12
- // import RavenVue from 'raven-js/plugins/vue';
11
+ import Raven from '@sentry/browser';
13
12
 
14
13
  class Report {
15
14
  static instance: any;
@@ -39,10 +38,10 @@ class Report {
39
38
  // raven内置了vue插件,会通过vue.config.errorHandler来捕获vue组件内错误并上报sentry服务
40
39
 
41
40
  // 记录用户信息
42
- Raven.setUserContext({ user: this.options.user || '' });
41
+ Raven.setUser({ user: this.options.user || '' });
43
42
 
44
43
  // 设置全局tag标签
45
- Raven.setTagsContext({ environment: this.options.env || '' });
44
+ Raven.setTag('environment', this.options.env || '');
46
45
  }
47
46
  }
48
47
 
@@ -54,7 +53,7 @@ class Report {
54
53
  */
55
54
  log(data: any = null, type: any = 'error', options: any = {}) {
56
55
  // 添加面包屑
57
- Raven.captureBreadcrumb({
56
+ Raven.addBreadcrumb({
58
57
  message: data,
59
58
  category: 'manual message',
60
59
  });
@@ -62,13 +61,11 @@ class Report {
62
61
  if (data instanceof Error) {
63
62
  Raven.captureException(data, {
64
63
  level: type,
65
- logger: 'manual exception',
66
64
  tags: { options },
67
65
  });
68
66
  } else {
69
67
  Raven.captureException('error', {
70
68
  level: type,
71
- logger: 'manual data',
72
69
  extra: {
73
70
  data,
74
71
  options: this.options,