nightingale-react-native-console 14.2.1 → 16.0.0

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/CHANGELOG.md CHANGED
@@ -3,6 +3,35 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## [16.0.0](https://github.com/christophehurpeau/nightingale/compare/v15.0.0...v16.0.0) (2025-03-30)
7
+
8
+ ### ⚠ BREAKING CHANGES
9
+
10
+ * drop node 18
11
+
12
+ ### Features
13
+
14
+ * drop node 18 ([1b11a55](https://github.com/christophehurpeau/nightingale/commit/1b11a55dd24c9435be50519a748316079f554414))
15
+
16
+ Version bump for dependency: nightingale
17
+ Version bump for dependency: nightingale-types
18
+
19
+
20
+ ## [15.0.0](https://github.com/christophehurpeau/nightingale/compare/v14.2.1...v15.0.0) (2023-12-25)
21
+
22
+
23
+ ### ⚠ BREAKING CHANGES
24
+
25
+ * update babel and drop browser modern version
26
+
27
+ ### Features
28
+
29
+ * update babel and drop browser modern version ([5c76abc](https://github.com/christophehurpeau/nightingale/commit/5c76abc8bfb595a617fc4c8b795dae7e674ea664))
30
+
31
+ Version bump for dependency: nightingale-ansi-formatter
32
+ Version bump for dependency: nightingale-types
33
+
34
+
6
35
  ## [14.2.1](https://github.com/christophehurpeau/nightingale/compare/v14.2.0...v14.2.1) (2023-11-05)
7
36
 
8
37
  Note: no notable changes
package/README.md CHANGED
@@ -1,16 +1,16 @@
1
- <h3 align="center">
1
+ <h1 align="center">
2
2
  nightingale-react-native-console
3
- </h3>
3
+ </h1>
4
4
 
5
5
  <p align="center">
6
6
  React Native and Expo handler for nightingale
7
7
  </p>
8
8
 
9
9
  <p align="center">
10
- <a href="https://npmjs.org/package/nightingale-react-native-console"><img src="https://img.shields.io/npm/v/nightingale-react-native-console.svg?style=flat-square"></a>
11
- <a href="https://npmjs.org/package/nightingale-react-native-console"><img src="https://img.shields.io/npm/dw/nightingale-react-native-console.svg?style=flat-square"></a>
12
- <a href="https://npmjs.org/package/nightingale-react-native-console"><img src="https://img.shields.io/node/v/nightingale-react-native-console.svg?style=flat-square"></a>
13
- <a href="https://npmjs.org/package/nightingale-react-native-console"><img src="https://img.shields.io/npm/types/nightingale-react-native-console.svg?style=flat-square"></a>
10
+ <a href="https://npmjs.org/package/nightingale-react-native-console"><img src="https://img.shields.io/npm/v/nightingale-react-native-console.svg?style=flat-square" alt="npm version"></a>
11
+ <a href="https://npmjs.org/package/nightingale-react-native-console"><img src="https://img.shields.io/npm/dw/nightingale-react-native-console.svg?style=flat-square" alt="npm downloads"></a>
12
+ <a href="https://npmjs.org/package/nightingale-react-native-console"><img src="https://img.shields.io/node/v/nightingale-react-native-console.svg?style=flat-square" alt="node version"></a>
13
+ <a href="https://npmjs.org/package/nightingale-react-native-console"><img src="https://img.shields.io/npm/types/nightingale-react-native-console.svg?style=flat-square" alt="types"></a>
14
14
  </p>
15
15
 
16
16
  ## Install
@@ -24,11 +24,11 @@ npm install --save nightingale nightingale-react-native-console
24
24
  :warn: This logger is meant for dev only.
25
25
 
26
26
  ```js
27
- import { configure, Level } from 'nightingale';
28
- import { ReactNativeConsoleHandler } from 'nightingale-react-native-console';
27
+ import { configure, Level } from "nightingale";
28
+ import { ReactNativeConsoleHandler } from "nightingale-react-native-console";
29
29
 
30
30
  configure(
31
- process.env.NODE_ENV === 'production'
31
+ process.env.NODE_ENV === "production"
32
32
  ? []
33
33
  : [
34
34
  {
@@ -1,4 +1,4 @@
1
- import type { Level, Handle, IsHandling, Handler } from 'nightingale-types';
1
+ import type { Handle, Handler, IsHandling, Level } from "nightingale-types";
2
2
  export declare class ReactNativeConsoleHandler implements Handler {
3
3
  minLevel: Level;
4
4
  handle: Handle;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,KAAK,EACL,MAAM,EACN,UAAU,EAGV,OAAO,EACR,MAAM,mBAAmB,CAAC;AA4D3B,qBAAa,yBAA0B,YAAW,OAAO;IACvD,QAAQ,EAAE,KAAK,CAAK;IAEpB,MAAM,EAAE,MAAM,CAAC;IAEf,UAAU,EAAE,UAAU,CAAC;gBAEX,QAAQ,EAAE,KAAK;CAK5B"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,MAAM,EACN,OAAO,EACP,UAAU,EACV,KAAK,EAGN,MAAM,mBAAmB,CAAC;AA6D3B,qBAAa,yBAA0B,YAAW,OAAO;IACvD,QAAQ,EAAE,KAAK,CAAK;IAEpB,MAAM,EAAE,MAAM,CAAC;IAEf,UAAU,EAAE,UAAU,CAAC;gBAEX,QAAQ,EAAE,KAAK;CAK5B"}
@@ -1,14 +1,13 @@
1
- import formatterANSI from 'nightingale-ansi-formatter';
1
+ import { ANSIFormatter } from 'nightingale';
2
2
  import { Platform } from 'react-native';
3
3
  import parseErrorStack from 'react-native/Libraries/Core/Devtools/parseErrorStack';
4
4
  import symbolicateStackTrace from 'react-native/Libraries/Core/Devtools/symbolicateStackTrace';
5
5
 
6
6
  /* eslint-disable @typescript-eslint/no-unsafe-argument */
7
- /* eslint-disable @typescript-eslint/no-unsafe-member-access */
8
7
 
9
- var getStackTrace = function getStackTrace(e) {
8
+ const getStackTrace = e => {
10
9
  // eslint-disable-next-line no-prototype-builtins
11
- if (Platform.hasOwnProperty('constants')) {
10
+ if (Platform.hasOwnProperty("constants")) {
12
11
  // RN version >= 0.63
13
12
  if (Platform.constants.reactNativeVersion.minor >= 64) {
14
13
  // RN version >= 0.64 -> Stacktrace as string
@@ -21,42 +20,39 @@ var getStackTrace = function getStackTrace(e) {
21
20
  else return parseErrorStack(e);
22
21
  };
23
22
  function parsedStackToString(stack) {
24
- return stack.map(function (frame) {
25
- return " at " + frame.file + (frame.lineNumber ? ":" + frame.lineNumber + (frame.column ? ":" + frame.column : '') : '') + (frame.methodName ? " in " + frame.methodName : '');
26
- }).join('\n');
23
+ return stack.map(frame => ` at ${frame.file}${frame.lineNumber ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ""}` : ""}${frame.methodName ? ` in ${frame.methodName}` : ""}`).join("\n");
27
24
  }
28
25
  function consoleOutput(param) {
29
- var _console;
30
26
  // eslint-disable-next-line no-console
31
- (_console = console).log.apply(_console, param);
27
+ console.log(...param);
32
28
  }
33
- var createHandle = function createHandle() {
34
- return function (record) {
35
- var _record$metadata;
36
- var metadataError = (_record$metadata = record.metadata) == null ? void 0 : _record$metadata.error;
29
+ const createHandle = () => {
30
+ return record => {
31
+ const metadataError = record.metadata?.error;
37
32
  if (metadataError && metadataError instanceof Error) {
38
- symbolicateStackTrace(getStackTrace(metadataError)).then(function (_ref) {
39
- var stack = _ref.stack;
40
- _ref.codeFrame;
33
+ symbolicateStackTrace(getStackTrace(metadataError)).then(({
34
+ stack,
35
+ codeFrame
36
+ }) => {
41
37
  metadataError.stack = parsedStackToString(stack);
42
- consoleOutput([formatterANSI(record)]);
43
- }).catch(function () {
38
+ consoleOutput([ANSIFormatter.format(record)]);
39
+ }).catch(() => {
44
40
  metadataError.stack = undefined;
45
- consoleOutput([formatterANSI(record)]);
41
+ consoleOutput([ANSIFormatter.format(record)]);
46
42
  });
47
43
  } else {
48
- consoleOutput([formatterANSI(record)]);
44
+ consoleOutput([ANSIFormatter.format(record)]);
49
45
  }
50
46
  };
51
47
  };
52
- var ReactNativeConsoleHandler = function ReactNativeConsoleHandler(minLevel) {
53
- this.minLevel = 0;
54
- this.minLevel = minLevel;
55
- this.isHandling = function (level) {
56
- return level >= minLevel;
57
- };
58
- this.handle = createHandle();
59
- };
48
+ class ReactNativeConsoleHandler {
49
+ minLevel = 0;
50
+ constructor(minLevel) {
51
+ this.minLevel = minLevel;
52
+ this.isHandling = level => level >= minLevel;
53
+ this.handle = createHandle();
54
+ }
55
+ }
60
56
 
61
57
  export { ReactNativeConsoleHandler };
62
58
  //# sourceMappingURL=index-browser.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-browser.es.js","sources":["../src/index.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unsafe-argument */\n/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n\nimport formatterANSI from 'nightingale-ansi-formatter';\nimport type {\n Level,\n Handle,\n IsHandling,\n LogRecord,\n Metadata,\n Handler,\n} from 'nightingale-types';\nimport { Platform } from 'react-native';\nimport parseErrorStack from 'react-native/Libraries/Core/Devtools/parseErrorStack';\nimport symbolicateStackTrace from 'react-native/Libraries/Core/Devtools/symbolicateStackTrace';\n\nconst getStackTrace = (e: Error): any => {\n // eslint-disable-next-line no-prototype-builtins\n if (Platform.hasOwnProperty('constants')) {\n // RN version >= 0.63\n if (Platform.constants.reactNativeVersion.minor >= 64) {\n // RN version >= 0.64 -> Stacktrace as string\n return parseErrorStack(e.stack as unknown as any);\n }\n // RN version == 0.63 -> Stacktrace as string\n else return parseErrorStack(e);\n }\n // RN version < 0.63 -> Stacktrace as string\n else return parseErrorStack(e);\n};\n\nfunction parsedStackToString(stack: any[]): string {\n return stack\n .map(\n (frame) =>\n ` at ${frame.file}${\n frame.lineNumber\n ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}`\n : ''\n }${frame.methodName ? ` in ${frame.methodName}` : ''}`,\n )\n .join('\\n');\n}\n\nfunction consoleOutput<T extends Metadata>(\n param: string[] | string,\n record: LogRecord<T>,\n): void {\n // eslint-disable-next-line no-console\n console.log(...param);\n}\n\nconst createHandle = (): Handle => {\n return <T extends Metadata>(record: LogRecord<T>): void => {\n const metadataError = record.metadata?.error;\n if (metadataError && metadataError instanceof Error) {\n symbolicateStackTrace(getStackTrace(metadataError))\n .then(({ stack, codeFrame }: any) => {\n metadataError.stack = parsedStackToString(stack);\n consoleOutput([formatterANSI(record)], record);\n })\n .catch((error) => {\n metadataError.stack = undefined;\n consoleOutput([formatterANSI(record)], record);\n });\n } else {\n consoleOutput([formatterANSI(record)], record);\n }\n };\n};\n\nexport class ReactNativeConsoleHandler implements Handler {\n minLevel: Level = 0;\n\n handle: Handle;\n\n isHandling: IsHandling;\n\n constructor(minLevel: Level) {\n this.minLevel = minLevel;\n this.isHandling = (level: Level) => level >= minLevel;\n this.handle = createHandle();\n }\n}\n"],"names":["getStackTrace","e","Platform","hasOwnProperty","constants","reactNativeVersion","minor","parseErrorStack","stack","parsedStackToString","map","frame","file","lineNumber","column","methodName","join","consoleOutput","param","_console","console","log","apply","createHandle","record","_record$metadata","metadataError","metadata","error","Error","symbolicateStackTrace","then","_ref","codeFrame","formatterANSI","catch","undefined","ReactNativeConsoleHandler","minLevel","isHandling","level","handle"],"mappings":"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"}
1
+ {"version":3,"file":"index-browser.es.js","sources":["../src/index.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unsafe-argument */\n\nimport { ANSIFormatter } from \"nightingale\";\nimport type {\n Handle,\n Handler,\n IsHandling,\n Level,\n LogRecord,\n Metadata,\n} from \"nightingale-types\";\nimport { Platform } from \"react-native\";\nimport type { StackFrame } from \"react-native/Libraries/Core/Devtools/parseErrorStack\";\nimport parseErrorStack from \"react-native/Libraries/Core/Devtools/parseErrorStack\";\nimport symbolicateStackTrace from \"react-native/Libraries/Core/Devtools/symbolicateStackTrace\";\n\nconst getStackTrace = (e: Error): any => {\n // eslint-disable-next-line no-prototype-builtins\n if (Platform.hasOwnProperty(\"constants\")) {\n // RN version >= 0.63\n if (Platform.constants.reactNativeVersion.minor >= 64) {\n // RN version >= 0.64 -> Stacktrace as string\n return parseErrorStack(e.stack as unknown as any);\n }\n // RN version == 0.63 -> Stacktrace as string\n else return parseErrorStack(e);\n }\n // RN version < 0.63 -> Stacktrace as string\n else return parseErrorStack(e);\n};\n\nfunction parsedStackToString(stack: StackFrame[]): string {\n return stack\n .map(\n (frame) =>\n ` at ${frame.file}${\n frame.lineNumber\n ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : \"\"}`\n : \"\"\n }${frame.methodName ? ` in ${frame.methodName}` : \"\"}`,\n )\n .join(\"\\n\");\n}\n\nfunction consoleOutput<T extends Metadata>(\n param: string[] | string,\n record: LogRecord<T>,\n): void {\n // eslint-disable-next-line no-console\n console.log(...(param as string[]));\n}\n\nconst createHandle = (): Handle => {\n return <T extends Metadata>(record: LogRecord<T>): void => {\n const metadataError = record.metadata?.error;\n if (metadataError && metadataError instanceof Error) {\n symbolicateStackTrace(getStackTrace(metadataError))\n .then(({ stack, codeFrame }: any) => {\n metadataError.stack = parsedStackToString(stack);\n consoleOutput([ANSIFormatter.format(record)], record);\n })\n .catch((error: unknown) => {\n metadataError.stack = undefined;\n consoleOutput([ANSIFormatter.format(record)], record);\n });\n } else {\n consoleOutput([ANSIFormatter.format(record)], record);\n }\n };\n};\n\nexport class ReactNativeConsoleHandler implements Handler {\n minLevel: Level = 0;\n\n handle: Handle;\n\n isHandling: IsHandling;\n\n constructor(minLevel: Level) {\n this.minLevel = minLevel;\n this.isHandling = (level: Level) => level >= minLevel;\n this.handle = createHandle();\n }\n}\n"],"names":["getStackTrace","e","Platform","hasOwnProperty","constants","reactNativeVersion","minor","parseErrorStack","stack","parsedStackToString","map","frame","file","lineNumber","column","methodName","join","consoleOutput","param","console","log","createHandle","record","metadataError","metadata","error","Error","symbolicateStackTrace","then","codeFrame","ANSIFormatter","format","catch","undefined","ReactNativeConsoleHandler","minLevel","constructor","isHandling","level","handle"],"mappings":";;;;;AAAA;;AAgBA,MAAMA,aAAa,GAAIC,CAAQ,IAAU;AACvC;AACA,EAAA,IAAIC,QAAQ,CAACC,cAAc,CAAC,WAAW,CAAC,EAAE;AACxC;IACA,IAAID,QAAQ,CAACE,SAAS,CAACC,kBAAkB,CAACC,KAAK,IAAI,EAAE,EAAE;AACrD;AACA,MAAA,OAAOC,eAAe,CAACN,CAAC,CAACO,KAAuB,CAAC;AACnD;AACA;AAAA,SACK,OAAOD,eAAe,CAACN,CAAC,CAAC;AAChC;AACA;AAAA,OACK,OAAOM,eAAe,CAACN,CAAC,CAAC;AAChC,CAAC;AAED,SAASQ,mBAAmBA,CAACD,KAAmB,EAAU;EACxD,OAAOA,KAAK,CACTE,GAAG,CACDC,KAAK,IACJ,CAAQA,KAAAA,EAAAA,KAAK,CAACC,IAAI,CAChBD,EAAAA,KAAK,CAACE,UAAU,GACZ,CAAIF,CAAAA,EAAAA,KAAK,CAACE,UAAU,GAAGF,KAAK,CAACG,MAAM,GAAG,CAAIH,CAAAA,EAAAA,KAAK,CAACG,MAAM,CAAA,CAAE,GAAG,EAAE,CAAE,CAAA,GAC/D,EAAE,CACLH,EAAAA,KAAK,CAACI,UAAU,GAAG,CAAA,IAAA,EAAOJ,KAAK,CAACI,UAAU,CAAE,CAAA,GAAG,EAAE,CAAA,CACxD,CAAC,CACAC,IAAI,CAAC,IAAI,CAAC;AACf;AAEA,SAASC,aAAaA,CACpBC,KAAwB,EAElB;AACN;AACAC,EAAAA,OAAO,CAACC,GAAG,CAAC,GAAIF,KAAkB,CAAC;AACrC;AAEA,MAAMG,YAAY,GAAGA,MAAc;AACjC,EAAA,OAA4BC,MAAoB,IAAW;AACzD,IAAA,MAAMC,aAAa,GAAGD,MAAM,CAACE,QAAQ,EAAEC,KAAK;AAC5C,IAAA,IAAIF,aAAa,IAAIA,aAAa,YAAYG,KAAK,EAAE;MACnDC,qBAAqB,CAAC3B,aAAa,CAACuB,aAAa,CAAC,CAAC,CAChDK,IAAI,CAAC,CAAC;QAAEpB,KAAK;AAAEqB,QAAAA;AAAe,OAAC,KAAK;AACnCN,QAAAA,aAAa,CAACf,KAAK,GAAGC,mBAAmB,CAACD,KAAK,CAAC;QAChDS,aAAa,CAAC,CAACa,aAAa,CAACC,MAAM,CAACT,MAAM,CAAC,CAAS,CAAC;AACvD,OAAC,CAAC,CACDU,KAAK,CAAC,MAAoB;QACzBT,aAAa,CAACf,KAAK,GAAGyB,SAAS;QAC/BhB,aAAa,CAAC,CAACa,aAAa,CAACC,MAAM,CAACT,MAAM,CAAC,CAAS,CAAC;AACvD,OAAC,CAAC;AACN,KAAC,MAAM;MACLL,aAAa,CAAC,CAACa,aAAa,CAACC,MAAM,CAACT,MAAM,CAAC,CAAS,CAAC;AACvD;GACD;AACH,CAAC;AAEM,MAAMY,yBAAyB,CAAoB;AACxDC,EAAAA,QAAQ,GAAU,CAAC;EAMnBC,WAAWA,CAACD,QAAe,EAAE;IAC3B,IAAI,CAACA,QAAQ,GAAGA,QAAQ;AACxB,IAAA,IAAI,CAACE,UAAU,GAAIC,KAAY,IAAKA,KAAK,IAAIH,QAAQ;AACrD,IAAA,IAAI,CAACI,MAAM,GAAGlB,YAAY,EAAE;AAC9B;AACF;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nightingale-react-native-console",
3
- "version": "14.2.1",
3
+ "version": "16.0.0",
4
4
  "description": "React Native and Expo handler for nightingale",
5
5
  "keywords": [
6
6
  "nightingale",
@@ -18,17 +18,9 @@
18
18
  "homepage": "https://github.com/christophehurpeau/nightingale",
19
19
  "type": "module",
20
20
  "engines": {
21
- "node": ">=18.12.0"
22
- },
23
- "browserslist": {
24
- "production": [
25
- "defaults",
26
- "> 0.2%",
27
- "not ie < 12",
28
- "not safari < 10",
29
- "not ios_saf < 10"
30
- ]
21
+ "node": ">=22.14.0"
31
22
  },
23
+ "sideEffects": false,
32
24
  "types": "./dist/definitions/index.d.ts",
33
25
  "module": "./dist/index-browser.es.js",
34
26
  "browser": "./dist/index-browser.es.js",
@@ -37,14 +29,10 @@
37
29
  ".": {
38
30
  "types": "./dist/definitions/index.d.ts",
39
31
  "browser": {
40
- "browser:modern": {
41
- "import": "./dist/index-browsermodern.es.js"
42
- },
43
32
  "import": "./dist/index-browser.es.js"
44
33
  }
45
34
  }
46
35
  },
47
- "sideEffects": false,
48
36
  "files": [
49
37
  "src",
50
38
  "dist"
@@ -55,37 +43,43 @@
55
43
  "clean": "yarn clean:build",
56
44
  "clean:build": "pob-babel-clean-out dist",
57
45
  "lint": "yarn run lint:eslint",
58
- "lint:eslint": "yarn ../.. run eslint --report-unused-disable-directives --resolve-plugins-relative-to . --quiet packages/nightingale-react-native-console",
46
+ "lint:eslint": "yarn ../.. run eslint --quiet packages/nightingale-react-native-console",
59
47
  "watch": "yarn clean:build && rollup --config rollup.config.mjs --watch"
60
48
  },
61
- "prettier": "@pob/root/prettier-config",
49
+ "browserslist": {
50
+ "production": [
51
+ "defaults",
52
+ "> 0.2%",
53
+ "not ie < 12",
54
+ "not safari < 10",
55
+ "not ios_saf < 10"
56
+ ]
57
+ },
62
58
  "pob": {
63
- "babelEnvs": [
64
- {
65
- "target": "browser",
66
- "version": "modern"
67
- },
59
+ "bundler": "rollup-babel",
60
+ "entries": [
61
+ "index"
62
+ ],
63
+ "envs": [
68
64
  {
69
65
  "target": "browser"
70
66
  }
71
- ],
72
- "entries": [
73
- "index"
74
67
  ]
75
68
  },
69
+ "prettier": "@pob/root/prettier-config",
76
70
  "peerDependencies": {
77
71
  "react-native": "*"
78
72
  },
79
73
  "dependencies": {
80
- "nightingale-ansi-formatter": "14.2.1",
81
- "nightingale-types": "14.2.1"
74
+ "nightingale": "16.0.0",
75
+ "nightingale-types": "16.0.0"
82
76
  },
83
77
  "devDependencies": {
84
- "@babel/core": "7.23.2",
85
- "@babel/preset-env": "7.23.2",
86
- "pob-babel": "36.6.1",
87
- "react": "18.2.0",
88
- "react-native": "0.72.6",
89
- "typescript": "5.2.2"
78
+ "@babel/core": "7.26.10",
79
+ "@babel/preset-env": "7.26.9",
80
+ "pob-babel": "43.4.0",
81
+ "react": "18.3.1",
82
+ "react-native": "0.77.0",
83
+ "typescript": "5.8.2"
90
84
  }
91
85
  }
package/src/index.ts CHANGED
@@ -1,22 +1,22 @@
1
1
  /* eslint-disable @typescript-eslint/no-unsafe-argument */
2
- /* eslint-disable @typescript-eslint/no-unsafe-member-access */
3
2
 
4
- import formatterANSI from 'nightingale-ansi-formatter';
3
+ import { ANSIFormatter } from "nightingale";
5
4
  import type {
6
- Level,
7
5
  Handle,
6
+ Handler,
8
7
  IsHandling,
8
+ Level,
9
9
  LogRecord,
10
10
  Metadata,
11
- Handler,
12
- } from 'nightingale-types';
13
- import { Platform } from 'react-native';
14
- import parseErrorStack from 'react-native/Libraries/Core/Devtools/parseErrorStack';
15
- import symbolicateStackTrace from 'react-native/Libraries/Core/Devtools/symbolicateStackTrace';
11
+ } from "nightingale-types";
12
+ import { Platform } from "react-native";
13
+ import type { StackFrame } from "react-native/Libraries/Core/Devtools/parseErrorStack";
14
+ import parseErrorStack from "react-native/Libraries/Core/Devtools/parseErrorStack";
15
+ import symbolicateStackTrace from "react-native/Libraries/Core/Devtools/symbolicateStackTrace";
16
16
 
17
17
  const getStackTrace = (e: Error): any => {
18
18
  // eslint-disable-next-line no-prototype-builtins
19
- if (Platform.hasOwnProperty('constants')) {
19
+ if (Platform.hasOwnProperty("constants")) {
20
20
  // RN version >= 0.63
21
21
  if (Platform.constants.reactNativeVersion.minor >= 64) {
22
22
  // RN version >= 0.64 -> Stacktrace as string
@@ -29,17 +29,17 @@ const getStackTrace = (e: Error): any => {
29
29
  else return parseErrorStack(e);
30
30
  };
31
31
 
32
- function parsedStackToString(stack: any[]): string {
32
+ function parsedStackToString(stack: StackFrame[]): string {
33
33
  return stack
34
34
  .map(
35
35
  (frame) =>
36
36
  ` at ${frame.file}${
37
37
  frame.lineNumber
38
- ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}`
39
- : ''
40
- }${frame.methodName ? ` in ${frame.methodName}` : ''}`,
38
+ ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ""}`
39
+ : ""
40
+ }${frame.methodName ? ` in ${frame.methodName}` : ""}`,
41
41
  )
42
- .join('\n');
42
+ .join("\n");
43
43
  }
44
44
 
45
45
  function consoleOutput<T extends Metadata>(
@@ -47,7 +47,7 @@ function consoleOutput<T extends Metadata>(
47
47
  record: LogRecord<T>,
48
48
  ): void {
49
49
  // eslint-disable-next-line no-console
50
- console.log(...param);
50
+ console.log(...(param as string[]));
51
51
  }
52
52
 
53
53
  const createHandle = (): Handle => {
@@ -57,14 +57,14 @@ const createHandle = (): Handle => {
57
57
  symbolicateStackTrace(getStackTrace(metadataError))
58
58
  .then(({ stack, codeFrame }: any) => {
59
59
  metadataError.stack = parsedStackToString(stack);
60
- consoleOutput([formatterANSI(record)], record);
60
+ consoleOutput([ANSIFormatter.format(record)], record);
61
61
  })
62
- .catch((error) => {
62
+ .catch((error: unknown) => {
63
63
  metadataError.stack = undefined;
64
- consoleOutput([formatterANSI(record)], record);
64
+ consoleOutput([ANSIFormatter.format(record)], record);
65
65
  });
66
66
  } else {
67
- consoleOutput([formatterANSI(record)], record);
67
+ consoleOutput([ANSIFormatter.format(record)], record);
68
68
  }
69
69
  };
70
70
  };
@@ -1,59 +0,0 @@
1
- import formatterANSI from 'nightingale-ansi-formatter';
2
- import { Platform } from 'react-native';
3
- import parseErrorStack from 'react-native/Libraries/Core/Devtools/parseErrorStack';
4
- import symbolicateStackTrace from 'react-native/Libraries/Core/Devtools/symbolicateStackTrace';
5
-
6
- /* eslint-disable @typescript-eslint/no-unsafe-argument */
7
- /* eslint-disable @typescript-eslint/no-unsafe-member-access */
8
-
9
- const getStackTrace = e => {
10
- // eslint-disable-next-line no-prototype-builtins
11
- if (Platform.hasOwnProperty('constants')) {
12
- // RN version >= 0.63
13
- if (Platform.constants.reactNativeVersion.minor >= 64) {
14
- // RN version >= 0.64 -> Stacktrace as string
15
- return parseErrorStack(e.stack);
16
- }
17
- // RN version == 0.63 -> Stacktrace as string
18
- else return parseErrorStack(e);
19
- }
20
- // RN version < 0.63 -> Stacktrace as string
21
- else return parseErrorStack(e);
22
- };
23
- function parsedStackToString(stack) {
24
- return stack.map(frame => ` at ${frame.file}${frame.lineNumber ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}` : ''}${frame.methodName ? ` in ${frame.methodName}` : ''}`).join('\n');
25
- }
26
- function consoleOutput(param) {
27
- // eslint-disable-next-line no-console
28
- console.log(...param);
29
- }
30
- const createHandle = () => {
31
- return record => {
32
- const metadataError = record.metadata?.error;
33
- if (metadataError && metadataError instanceof Error) {
34
- symbolicateStackTrace(getStackTrace(metadataError)).then(({
35
- stack,
36
- codeFrame
37
- }) => {
38
- metadataError.stack = parsedStackToString(stack);
39
- consoleOutput([formatterANSI(record)]);
40
- }).catch(() => {
41
- metadataError.stack = undefined;
42
- consoleOutput([formatterANSI(record)]);
43
- });
44
- } else {
45
- consoleOutput([formatterANSI(record)]);
46
- }
47
- };
48
- };
49
- class ReactNativeConsoleHandler {
50
- minLevel = 0;
51
- constructor(minLevel) {
52
- this.minLevel = minLevel;
53
- this.isHandling = level => level >= minLevel;
54
- this.handle = createHandle();
55
- }
56
- }
57
-
58
- export { ReactNativeConsoleHandler };
59
- //# sourceMappingURL=index-browsermodern.es.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-browsermodern.es.js","sources":["../src/index.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unsafe-argument */\n/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n\nimport formatterANSI from 'nightingale-ansi-formatter';\nimport type {\n Level,\n Handle,\n IsHandling,\n LogRecord,\n Metadata,\n Handler,\n} from 'nightingale-types';\nimport { Platform } from 'react-native';\nimport parseErrorStack from 'react-native/Libraries/Core/Devtools/parseErrorStack';\nimport symbolicateStackTrace from 'react-native/Libraries/Core/Devtools/symbolicateStackTrace';\n\nconst getStackTrace = (e: Error): any => {\n // eslint-disable-next-line no-prototype-builtins\n if (Platform.hasOwnProperty('constants')) {\n // RN version >= 0.63\n if (Platform.constants.reactNativeVersion.minor >= 64) {\n // RN version >= 0.64 -> Stacktrace as string\n return parseErrorStack(e.stack as unknown as any);\n }\n // RN version == 0.63 -> Stacktrace as string\n else return parseErrorStack(e);\n }\n // RN version < 0.63 -> Stacktrace as string\n else return parseErrorStack(e);\n};\n\nfunction parsedStackToString(stack: any[]): string {\n return stack\n .map(\n (frame) =>\n ` at ${frame.file}${\n frame.lineNumber\n ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}`\n : ''\n }${frame.methodName ? ` in ${frame.methodName}` : ''}`,\n )\n .join('\\n');\n}\n\nfunction consoleOutput<T extends Metadata>(\n param: string[] | string,\n record: LogRecord<T>,\n): void {\n // eslint-disable-next-line no-console\n console.log(...param);\n}\n\nconst createHandle = (): Handle => {\n return <T extends Metadata>(record: LogRecord<T>): void => {\n const metadataError = record.metadata?.error;\n if (metadataError && metadataError instanceof Error) {\n symbolicateStackTrace(getStackTrace(metadataError))\n .then(({ stack, codeFrame }: any) => {\n metadataError.stack = parsedStackToString(stack);\n consoleOutput([formatterANSI(record)], record);\n })\n .catch((error) => {\n metadataError.stack = undefined;\n consoleOutput([formatterANSI(record)], record);\n });\n } else {\n consoleOutput([formatterANSI(record)], record);\n }\n };\n};\n\nexport class ReactNativeConsoleHandler implements Handler {\n minLevel: Level = 0;\n\n handle: Handle;\n\n isHandling: IsHandling;\n\n constructor(minLevel: Level) {\n this.minLevel = minLevel;\n this.isHandling = (level: Level) => level >= minLevel;\n this.handle = createHandle();\n }\n}\n"],"names":["getStackTrace","e","Platform","hasOwnProperty","constants","reactNativeVersion","minor","parseErrorStack","stack","parsedStackToString","map","frame","file","lineNumber","column","methodName","join","consoleOutput","param","console","log","createHandle","record","metadataError","metadata","error","Error","symbolicateStackTrace","then","codeFrame","formatterANSI","catch","undefined","ReactNativeConsoleHandler","minLevel","constructor","isHandling","level","handle"],"mappings":";;;;;AAAA;AACA;;AAeA,MAAMA,aAAa,GAAIC,CAAQ,IAAU;AACvC;AACA,EAAA,IAAIC,QAAQ,CAACC,cAAc,CAAC,WAAW,CAAC,EAAE;AACxC;IACA,IAAID,QAAQ,CAACE,SAAS,CAACC,kBAAkB,CAACC,KAAK,IAAI,EAAE,EAAE;AACrD;AACA,MAAA,OAAOC,eAAe,CAACN,CAAC,CAACO,KAAuB,CAAC,CAAA;AACnD,KAAA;AACA;AAAA,SACK,OAAOD,eAAe,CAACN,CAAC,CAAC,CAAA;AAChC,GAAA;AACA;AAAA,OACK,OAAOM,eAAe,CAACN,CAAC,CAAC,CAAA;AAChC,CAAC,CAAA;AAED,SAASQ,mBAAmBA,CAACD,KAAY,EAAU;EACjD,OAAOA,KAAK,CACTE,GAAG,CACDC,KAAK,IACH,CAAOA,KAAAA,EAAAA,KAAK,CAACC,IAAK,CACjBD,EAAAA,KAAK,CAACE,UAAU,GACX,CAAGF,CAAAA,EAAAA,KAAK,CAACE,UAAW,GAAEF,KAAK,CAACG,MAAM,GAAI,CAAGH,CAAAA,EAAAA,KAAK,CAACG,MAAO,CAAA,CAAC,GAAG,EAAG,CAAC,CAAA,GAC/D,EACL,CAAEH,EAAAA,KAAK,CAACI,UAAU,GAAI,CAAA,IAAA,EAAMJ,KAAK,CAACI,UAAW,CAAC,CAAA,GAAG,EAAG,CAAA,CACzD,CAAC,CACAC,IAAI,CAAC,IAAI,CAAC,CAAA;AACf,CAAA;AAEA,SAASC,aAAaA,CACpBC,KAAwB,EAElB;AACN;AACAC,EAAAA,OAAO,CAACC,GAAG,CAAC,GAAGF,KAAK,CAAC,CAAA;AACvB,CAAA;AAEA,MAAMG,YAAY,GAAGA,MAAc;AACjC,EAAA,OAA4BC,MAAoB,IAAW;AACzD,IAAA,MAAMC,aAAa,GAAGD,MAAM,CAACE,QAAQ,EAAEC,KAAK,CAAA;AAC5C,IAAA,IAAIF,aAAa,IAAIA,aAAa,YAAYG,KAAK,EAAE;MACnDC,qBAAqB,CAAC3B,aAAa,CAACuB,aAAa,CAAC,CAAC,CAChDK,IAAI,CAAC,CAAC;QAAEpB,KAAK;AAAEqB,QAAAA,SAAAA;AAAe,OAAC,KAAK;AACnCN,QAAAA,aAAa,CAACf,KAAK,GAAGC,mBAAmB,CAACD,KAAK,CAAC,CAAA;QAChDS,aAAa,CAAC,CAACa,aAAa,CAACR,MAAM,CAAC,CAAS,CAAC,CAAA;AAChD,OAAC,CAAC,CACDS,KAAK,CAAC,MAAW;QAChBR,aAAa,CAACf,KAAK,GAAGwB,SAAS,CAAA;QAC/Bf,aAAa,CAAC,CAACa,aAAa,CAACR,MAAM,CAAC,CAAS,CAAC,CAAA;AAChD,OAAC,CAAC,CAAA;AACN,KAAC,MAAM;MACLL,aAAa,CAAC,CAACa,aAAa,CAACR,MAAM,CAAC,CAAS,CAAC,CAAA;AAChD,KAAA;GACD,CAAA;AACH,CAAC,CAAA;AAEM,MAAMW,yBAAyB,CAAoB;AACxDC,EAAAA,QAAQ,GAAU,CAAC,CAAA;EAMnBC,WAAWA,CAACD,QAAe,EAAE;IAC3B,IAAI,CAACA,QAAQ,GAAGA,QAAQ,CAAA;AACxB,IAAA,IAAI,CAACE,UAAU,GAAIC,KAAY,IAAKA,KAAK,IAAIH,QAAQ,CAAA;AACrD,IAAA,IAAI,CAACI,MAAM,GAAGjB,YAAY,EAAE,CAAA;AAC9B,GAAA;AACF;;;;"}
@@ -1,27 +0,0 @@
1
- {
2
- "root": true,
3
- "parser": "@typescript-eslint/parser",
4
- "parserOptions": {
5
- "project": "packages/nightingale-react-native-console/tsconfig.json"
6
- },
7
- "plugins": ["@typescript-eslint"],
8
- "extends": ["@pob/eslint-config-typescript"],
9
- "ignorePatterns": ["*.d.ts"],
10
- "overrides": [
11
- {
12
- "files": ["**/*.test.ts", "__tests__/**/*.ts"],
13
- "extends": ["@pob/eslint-config-typescript/test"],
14
- "env": {
15
- "jest": true
16
- },
17
- "rules": {
18
- "import/no-extraneous-dependencies": [
19
- "error",
20
- {
21
- "devDependencies": true
22
- }
23
- ]
24
- }
25
- }
26
- ]
27
- }