nightingale-react-native-console 17.0.1 → 18.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,20 @@
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
+ ## [18.0.0](https://github.com/christophehurpeau/nightingale/compare/v17.0.1...v18.0.0) (2025-11-15)
7
+
8
+ ### ⚠ BREAKING CHANGES
9
+
10
+ * drop node 20
11
+
12
+ ### Features
13
+
14
+ * update dependencies
15
+
16
+ Version bump for dependency: nightingale
17
+ Version bump for dependency: nightingale-types
18
+
19
+
6
20
  ## [17.0.1](https://github.com/christophehurpeau/nightingale/compare/v17.0.0...v17.0.1) (2025-10-22)
7
21
 
8
22
  Version bump for dependency: nightingale
@@ -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[],\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;;;;"}
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,IAClD,CAAA,MAEK,OAAO,eAAA,CAAgB,CAAC,CAAA;AAAA,EAC/B,CAAA,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,MACpD,CAAC,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,MACpD,CAAC,CAAA;AAAA,IACL,CAAA,MAAO;AACL,MAAA,aAAA,CAAc,aAAA,CAAc,MAAA,CAAO,MAAM,CAAS,CAAA;AAAA,IACpD;AAAA,EACF,CAAA;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,EAC7B;AACF;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nightingale-react-native-console",
3
- "version": "17.0.1",
3
+ "version": "18.0.0",
4
4
  "description": "React Native and Expo handler for nightingale",
5
5
  "keywords": [
6
6
  "nightingale",
@@ -18,7 +18,7 @@
18
18
  "homepage": "https://github.com/christophehurpeau/nightingale",
19
19
  "type": "module",
20
20
  "engines": {
21
- "node": ">=22.14.0"
21
+ "node": ">=22.18.0"
22
22
  },
23
23
  "sideEffects": false,
24
24
  "types": "./dist/definitions/index.d.ts",
@@ -28,9 +28,6 @@
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
- },
34
31
  "browser": {
35
32
  "import": "./dist/index-browser.es.js"
36
33
  }
@@ -75,15 +72,15 @@
75
72
  "react-native": "*"
76
73
  },
77
74
  "dependencies": {
78
- "nightingale": "17.0.1",
79
- "nightingale-types": "17.0.0"
75
+ "nightingale": "18.0.0",
76
+ "nightingale-types": "18.0.0"
80
77
  },
81
78
  "devDependencies": {
82
- "@pob/rollup-esbuild": "6.7.0",
79
+ "@pob/rollup-esbuild": "7.3.2",
83
80
  "react": "19.1.0",
84
81
  "react-dom": "19.1.0",
85
82
  "react-native": "0.80.0",
86
- "react-native-web": "0.21.1",
87
- "typescript": "5.9.2"
83
+ "react-native-web": "0.21.2",
84
+ "typescript": "5.9.3"
88
85
  }
89
86
  }