nightingale-react-native-console 16.2.0 → 17.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,21 @@
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
+ ## [17.0.0](https://github.com/christophehurpeau/nightingale/compare/v16.2.0...v17.0.0) (2025-10-20)
7
+
8
+ ### ⚠ BREAKING CHANGES
9
+
10
+ * harmonize formatter return type
11
+
12
+ ### Features
13
+
14
+ * add export for react-native ([4098304](https://github.com/christophehurpeau/nightingale/commit/4098304ff9b6665930b7316fe05e0baf0b2e3fe5))
15
+ * harmonize formatter return type ([62771db](https://github.com/christophehurpeau/nightingale/commit/62771db963ee6a48de0a05a41aa4f5f09ac14d19))
16
+
17
+ Version bump for dependency: nightingale
18
+ Version bump for dependency: nightingale-types
19
+
20
+
6
21
  ## [16.2.0](https://github.com/christophehurpeau/nightingale/compare/v16.1.0...v16.2.0) (2025-03-30)
7
22
 
8
23
  Version bump for dependency: nightingale
@@ -1,55 +1,44 @@
1
1
  import { ANSIFormatter } from 'nightingale';
2
- import { Platform } from 'react-native';
2
+ import { Platform } from 'react-native-web';
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
- /* eslint-disable @typescript-eslint/no-unsafe-argument */
7
-
8
- const getStackTrace = e => {
9
- // eslint-disable-next-line no-prototype-builtins
6
+ const getStackTrace = (e) => {
10
7
  if (Platform.hasOwnProperty("constants")) {
11
- // RN version >= 0.63
12
8
  if (Platform.constants.reactNativeVersion.minor >= 64) {
13
- // RN version >= 0.64 -> Stacktrace as string
14
9
  return parseErrorStack(e.stack);
15
- }
16
- // RN version == 0.63 -> Stacktrace as string
17
- else return parseErrorStack(e);
18
- }
19
- // RN version < 0.63 -> Stacktrace as string
20
- else return parseErrorStack(e);
10
+ } else return parseErrorStack(e);
11
+ } else return parseErrorStack(e);
21
12
  };
22
13
  function parsedStackToString(stack) {
23
- return stack.map(frame => ` at ${frame.file}${frame.lineNumber ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ""}` : ""}${frame.methodName ? ` in ${frame.methodName}` : ""}`).join("\n");
14
+ return stack.map(
15
+ (frame) => ` at ${frame.file}${frame.lineNumber ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ""}` : ""}${frame.methodName ? ` in ${frame.methodName}` : ""}`
16
+ ).join("\n");
24
17
  }
25
- function consoleOutput(param) {
26
- // eslint-disable-next-line no-console
18
+ function consoleOutput(param, record) {
27
19
  console.log(...param);
28
20
  }
29
21
  const createHandle = () => {
30
- return record => {
22
+ return (record) => {
31
23
  const metadataError = record.metadata?.error;
32
24
  if (metadataError && metadataError instanceof Error) {
33
- symbolicateStackTrace(getStackTrace(metadataError)).then(({
34
- stack,
35
- codeFrame
36
- }) => {
25
+ symbolicateStackTrace(getStackTrace(metadataError)).then(({ stack, codeFrame }) => {
37
26
  metadataError.stack = parsedStackToString(stack);
38
- consoleOutput([ANSIFormatter.format(record)]);
39
- }).catch(() => {
40
- metadataError.stack = undefined;
41
- consoleOutput([ANSIFormatter.format(record)]);
27
+ consoleOutput(ANSIFormatter.format(record));
28
+ }).catch((error) => {
29
+ metadataError.stack = void 0;
30
+ consoleOutput(ANSIFormatter.format(record));
42
31
  });
43
32
  } else {
44
- consoleOutput([ANSIFormatter.format(record)]);
33
+ consoleOutput(ANSIFormatter.format(record));
45
34
  }
46
35
  };
47
36
  };
48
37
  class ReactNativeConsoleHandler {
49
- minLevel = 0;
50
38
  constructor(minLevel) {
39
+ this.minLevel = 0;
51
40
  this.minLevel = minLevel;
52
- this.isHandling = level => level >= minLevel;
41
+ this.isHandling = (level) => level >= minLevel;
53
42
  this.handle = createHandle();
54
43
  }
55
44
  }
@@ -1 +1 @@
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;;;;"}
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[],\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(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":[],"mappings":";;;;;AAgBA,MAAM,aAAA,GAAgB,CAAC,CAAA,KAAkB;AAEvC,EAAA,IAAI,QAAA,CAAS,cAAA,CAAe,WAAW,CAAA,EAAG;AAExC,IAAA,IAAI,QAAA,CAAS,SAAA,CAAU,kBAAA,CAAmB,KAAA,IAAS,EAAA,EAAI;AAErD,MAAA,OAAO,eAAA,CAAgB,EAAE,KAAuB,CAAA;AAAA,KAClD,MAEK,OAAO,eAAA,CAAgB,CAAC,CAAA;AAAA,GAC/B,MAEK,OAAO,eAAA,CAAgB,CAAC,CAAA;AAC/B,CAAA;AAEA,SAAS,oBAAoB,KAAA,EAA6B;AACxD,EAAA,OAAO,KAAA,CACJ,GAAA;AAAA,IACC,CAAC,KAAA,KACC,CAAA,KAAA,EAAQ,KAAA,CAAM,IAAI,CAAA,EAChB,KAAA,CAAM,UAAA,GACF,CAAA,CAAA,EAAI,KAAA,CAAM,UAAU,CAAA,EAAG,KAAA,CAAM,MAAA,GAAS,CAAA,CAAA,EAAI,KAAA,CAAM,MAAM,CAAA,CAAA,GAAK,EAAE,CAAA,CAAA,GAC7D,EACN,CAAA,EAAG,KAAA,CAAM,UAAA,GAAa,CAAA,IAAA,EAAO,KAAA,CAAM,UAAU,CAAA,CAAA,GAAK,EAAE,CAAA;AAAA,GACxD,CACC,KAAK,IAAI,CAAA;AACd;AAEA,SAAS,aAAA,CACP,OACA,MAAA,EACM;AAEN,EAAA,OAAA,CAAQ,GAAA,CAAI,GAAG,KAAK,CAAA;AACtB;AAEA,MAAM,eAAe,MAAc;AACjC,EAAA,OAAO,CAAqB,MAAA,KAA+B;AACzD,IAAA,MAAM,aAAA,GAAgB,OAAO,QAAA,EAAU,KAAA;AACvC,IAAA,IAAI,aAAA,IAAiB,yBAAyB,KAAA,EAAO;AACnD,MAAA,qBAAA,CAAsB,aAAA,CAAc,aAAa,CAAC,CAAA,CAC/C,KAAK,CAAC,EAAE,KAAA,EAAO,SAAA,EAAU,KAAW;AACnC,QAAA,aAAA,CAAc,KAAA,GAAQ,oBAAoB,KAAK,CAAA;AAC/C,QAAA,aAAA,CAAc,aAAA,CAAc,MAAA,CAAO,MAAM,CAAS,CAAA;AAAA,OACnD,CAAA,CACA,KAAA,CAAM,CAAC,KAAA,KAAmB;AACzB,QAAA,aAAA,CAAc,KAAA,GAAQ,MAAA;AACtB,QAAA,aAAA,CAAc,aAAA,CAAc,MAAA,CAAO,MAAM,CAAS,CAAA;AAAA,OACnD,CAAA;AAAA,KACL,MAAO;AACL,MAAA,aAAA,CAAc,aAAA,CAAc,MAAA,CAAO,MAAM,CAAS,CAAA;AAAA;AACpD,GACF;AACF,CAAA;AAEO,MAAM,yBAAA,CAA6C;AAAA,EAOxD,YAAY,QAAA,EAAiB;AAN7B,IAAA,IAAA,CAAA,QAAA,GAAkB,CAAA;AAOhB,IAAA,IAAA,CAAK,QAAA,GAAW,QAAA;AAChB,IAAA,IAAA,CAAK,UAAA,GAAa,CAAC,KAAA,KAAiB,KAAA,IAAS,QAAA;AAC7C,IAAA,IAAA,CAAK,SAAS,YAAA,EAAa;AAAA;AAE/B;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nightingale-react-native-console",
3
- "version": "16.2.0",
3
+ "version": "17.0.0",
4
4
  "description": "React Native and Expo handler for nightingale",
5
5
  "keywords": [
6
6
  "nightingale",
@@ -28,6 +28,9 @@
28
28
  "./package.json": "./package.json",
29
29
  ".": {
30
30
  "types": "./dist/definitions/index.d.ts",
31
+ "react-native": {
32
+ "import": "./dist/index-browser.es.js"
33
+ },
31
34
  "browser": {
32
35
  "import": "./dist/index-browser.es.js"
33
36
  }
@@ -41,7 +44,7 @@
41
44
  "build": "yarn clean:build && rollup --config rollup.config.mjs && yarn run build:definitions",
42
45
  "build:definitions": "tsc -p tsconfig.json",
43
46
  "clean": "yarn clean:build",
44
- "clean:build": "pob-babel-clean-out dist",
47
+ "clean:build": "pob-esbuild-clean-out dist",
45
48
  "lint": "yarn run lint:eslint",
46
49
  "lint:eslint": "yarn ../.. run eslint --quiet packages/nightingale-react-native-console",
47
50
  "watch": "yarn clean:build && rollup --config rollup.config.mjs --watch"
@@ -56,7 +59,7 @@
56
59
  ]
57
60
  },
58
61
  "pob": {
59
- "bundler": "rollup-babel",
62
+ "bundler": "rollup-esbuild",
60
63
  "entries": [
61
64
  "index"
62
65
  ],
@@ -64,22 +67,23 @@
64
67
  {
65
68
  "target": "browser"
66
69
  }
67
- ]
70
+ ],
71
+ "typescript": true
68
72
  },
69
73
  "prettier": "@pob/root/prettier-config",
70
74
  "peerDependencies": {
71
75
  "react-native": "*"
72
76
  },
73
77
  "dependencies": {
74
- "nightingale": "16.2.0",
75
- "nightingale-types": "16.0.0"
78
+ "nightingale": "17.0.0",
79
+ "nightingale-types": "17.0.0"
76
80
  },
77
81
  "devDependencies": {
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"
82
+ "@pob/rollup-esbuild": "6.7.0",
83
+ "react": "19.1.0",
84
+ "react-dom": "19.1.0",
85
+ "react-native": "0.80.0",
86
+ "react-native-web": "0.21.1",
87
+ "typescript": "5.9.2"
84
88
  }
85
89
  }
package/src/index.ts CHANGED
@@ -43,11 +43,11 @@ function parsedStackToString(stack: StackFrame[]): string {
43
43
  }
44
44
 
45
45
  function consoleOutput<T extends Metadata>(
46
- param: string[] | string,
46
+ param: string[],
47
47
  record: LogRecord<T>,
48
48
  ): void {
49
49
  // eslint-disable-next-line no-console
50
- console.log(...(param as string[]));
50
+ console.log(...param);
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([ANSIFormatter.format(record)], record);
60
+ consoleOutput(ANSIFormatter.format(record), record);
61
61
  })
62
62
  .catch((error: unknown) => {
63
63
  metadataError.stack = undefined;
64
- consoleOutput([ANSIFormatter.format(record)], record);
64
+ consoleOutput(ANSIFormatter.format(record), record);
65
65
  });
66
66
  } else {
67
- consoleOutput([ANSIFormatter.format(record)], record);
67
+ consoleOutput(ANSIFormatter.format(record), record);
68
68
  }
69
69
  };
70
70
  };