nightingale-react-native-console 12.1.4 → 14.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,47 @@
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
+ ## [14.0.0](https://github.com/christophehurpeau/nightingale/compare/v13.0.0...v14.0.0) (2023-06-30)
7
+
8
+
9
+ ### ⚠ BREAKING CHANGES
10
+
11
+ * **deps:** require node 18
12
+ * requires node 18
13
+
14
+ ### Features
15
+
16
+ * requires node 18 ([4452b11](https://github.com/christophehurpeau/nightingale/commit/4452b116188e58c293be85e462e04922f7ad51f0))
17
+
18
+
19
+ ### Miscellaneous Chores
20
+
21
+ * **deps:** update dependency @pob/root to v8 ([#760](https://github.com/christophehurpeau/nightingale/issues/760)) ([22dc3cc](https://github.com/christophehurpeau/nightingale/commit/22dc3cceabdfd465d04ee36fec8fdac31febab69))
22
+
23
+
24
+
25
+ # [13.0.0](https://github.com/christophehurpeau/nightingale/compare/v12.1.4...v13.0.0) (2022-11-19)
26
+
27
+
28
+ ### Code Refactoring
29
+
30
+ * drop node 14 and cjs ([9a8ca06](https://github.com/christophehurpeau/nightingale/commit/9a8ca064449ddc0d69e26543e21c2d522536c50a))
31
+
32
+
33
+ ### Features
34
+
35
+ * build for node 16 ([30ae3e9](https://github.com/christophehurpeau/nightingale/commit/30ae3e9c455dbad793c2f704b9d860069dc80c32))
36
+
37
+
38
+ ### BREAKING CHANGES
39
+
40
+ * dropped node 14 and cjs
41
+ * drop node 14
42
+
43
+
44
+
45
+
46
+
6
47
  ## [12.1.4](https://github.com/christophehurpeau/nightingale/compare/v12.1.3...v12.1.4) (2022-02-05)
7
48
 
8
49
 
package/README.md CHANGED
@@ -8,6 +8,9 @@
8
8
 
9
9
  <p align="center">
10
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>
11
14
  </p>
12
15
 
13
16
  ## Install
@@ -0,0 +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"}
@@ -4,7 +4,8 @@ import parseErrorStack from 'react-native/Libraries/Core/Devtools/parseErrorStac
4
4
  import symbolicateStackTrace from 'react-native/Libraries/Core/Devtools/symbolicateStackTrace';
5
5
 
6
6
  /* eslint-disable @typescript-eslint/no-unsafe-argument */
7
-
7
+ /* eslint-disable @typescript-eslint/no-unsafe-member-access */
8
+ /* eslint-disable @typescript-eslint/restrict-template-expressions */
8
9
  var getStackTrace = function getStackTrace(e) {
9
10
  // eslint-disable-next-line no-prototype-builtins
10
11
  if (Platform.hasOwnProperty('constants')) {
@@ -12,37 +13,33 @@ var getStackTrace = function getStackTrace(e) {
12
13
  if (Platform.constants.reactNativeVersion.minor >= 64) {
13
14
  // RN version >= 0.64 -> Stacktrace as string
14
15
  return parseErrorStack(e.stack);
15
- } // RN version == 0.63 -> Stacktrace as string
16
+ }
17
+ // RN version == 0.63 -> Stacktrace as string
16
18
  else return parseErrorStack(e);
17
- } // RN version < 0.63 -> Stacktrace as string
19
+ }
20
+ // RN version < 0.63 -> Stacktrace as string
18
21
  else return parseErrorStack(e);
19
22
  };
20
-
21
23
  function parsedStackToString(stack) {
22
24
  return stack.map(function (frame) {
23
25
  return " at " + frame.file + (frame.lineNumber ? ":" + frame.lineNumber + (frame.column ? ":" + frame.column : '') : '') + (frame.methodName ? " in " + frame.methodName : '');
24
26
  }).join('\n');
25
27
  }
26
-
27
28
  function consoleOutput(param) {
28
29
  var _console;
29
-
30
30
  // eslint-disable-next-line no-console
31
31
  (_console = console).log.apply(_console, param);
32
32
  }
33
-
34
33
  var createHandle = function createHandle() {
35
34
  return function (record) {
36
35
  var _record$metadata, _record$metadata2;
37
-
38
- var error = (_record$metadata = record.metadata) == null ? void 0 : _record$metadata.error;
39
-
40
- if (error && error instanceof Error) {
36
+ var metadataError = (_record$metadata = record.metadata) == null ? void 0 : _record$metadata.error;
37
+ if (metadataError && metadataError instanceof Error) {
41
38
  (_record$metadata2 = record.metadata) == null ? true : delete _record$metadata2.error;
42
- symbolicateStackTrace(getStackTrace(error)).then(function (_ref) {
39
+ symbolicateStackTrace(getStackTrace(metadataError)).then(function (_ref) {
43
40
  var stack = _ref.stack;
44
- _ref.codeFrame;
45
- error.stack = parsedStackToString(stack);
41
+ _ref.codeFrame;
42
+ metadataError.stack = parsedStackToString(stack);
46
43
  consoleOutput([formatterANSI(record)]);
47
44
  }).catch(function () {
48
45
  consoleOutput([formatterANSI(record)]);
@@ -52,15 +49,12 @@ var createHandle = function createHandle() {
52
49
  }
53
50
  };
54
51
  };
55
-
56
52
  var ReactNativeConsoleHandler = function ReactNativeConsoleHandler(minLevel) {
57
53
  this.minLevel = 0;
58
54
  this.minLevel = minLevel;
59
-
60
55
  this.isHandling = function (level) {
61
56
  return level >= minLevel;
62
57
  };
63
-
64
58
  this.handle = createHandle();
65
59
  };
66
60
 
@@ -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/* eslint-disable @typescript-eslint/restrict-template-expressions */\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 error = record.metadata?.error;\n if (error && error instanceof Error) {\n delete record.metadata?.error;\n symbolicateStackTrace(getStackTrace(error))\n .then(({ stack, codeFrame }: any) => {\n error.stack = parsedStackToString(stack);\n consoleOutput([formatterANSI(record)], record);\n })\n .catch((err) => {\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","error","metadata","Error","symbolicateStackTrace","then","codeFrame","formatterANSI","catch","ReactNativeConsoleHandler","minLevel","isHandling","level","handle"],"mappings":";;;;;AAAA;;AAgBA,IAAMA,aAAa,GAAG,SAAhBA,aAAgB,CAACC,CAAD,EAAmB;AACvC;AACA,MAAIC,QAAQ,CAACC,cAAT,CAAwB,WAAxB,CAAJ,EAA0C;AACxC;AACA,QAAID,QAAQ,CAACE,SAAT,CAAmBC,kBAAnB,CAAsCC,KAAtC,IAA+C,EAAnD,EAAuD;AACrD;AACA,aAAOC,eAAe,CAACN,CAAC,CAACO,KAAH,CAAtB;AACD,KAHD;AAAA,SAKK,OAAOD,eAAe,CAACN,CAAD,CAAtB;AACN,GARD;AAAA,OAUK,OAAOM,eAAe,CAACN,CAAD,CAAtB;AACN,CAbD;;AAeA,SAASQ,mBAAT,CAA6BD,KAA7B,EAAmD;AACjD,SAAOA,KAAK,CACTE,GADI,CAEH,UAACC,KAAD;AAAA,qBACUA,KAAK,CAACC,IADhB,IAEID,KAAK,CAACE,UAAN,SACQF,KAAK,CAACE,UADd,IAC2BF,KAAK,CAACG,MAAN,SAAmBH,KAAK,CAACG,MAAzB,GAAoC,EAD/D,IAEI,EAJR,KAKKH,KAAK,CAACI,UAAN,YAA0BJ,KAAK,CAACI,UAAhC,GAA+C,EALpD;AAAA,GAFG,EASJC,IATI,CASC,IATD,CAAP;AAUD;;AAED,SAASC,aAAT,CACEC,KADF,EAGQ;AAAA;;AACN;AACA,cAAAC,OAAO,EAACC,GAAR,iBAAeF,KAAf;AACD;;AAED,IAAMG,YAAY,GAAG,SAAfA,YAAe,GAAc;AACjC,SAAO,UAAqBC,MAArB,EAAoD;AAAA;;AACzD,QAAMC,KAAK,uBAAGD,MAAM,CAACE,QAAV,qBAAG,iBAAiBD,KAA/B;;AACA,QAAIA,KAAK,IAAIA,KAAK,YAAYE,KAA9B,EAAqC;AACnC,2BAAOH,MAAM,CAACE,QAAd,0BAAO,kBAAiBD,KAAxB;AACAG,MAAAA,qBAAqB,CAAC1B,aAAa,CAACuB,KAAD,CAAd,CAArB,CACGI,IADH,CACQ,gBAA+B;AAAA,YAA5BnB,KAA4B,QAA5BA,KAA4B;AAAA,iBAArBoB;AACdL,QAAAA,KAAK,CAACf,KAAN,GAAcC,mBAAmB,CAACD,KAAD,CAAjC;AACAS,QAAAA,aAAa,CAAC,CAACY,aAAa,CAACP,MAAD,CAAd,CAAD,CAAb;AACD,OAJH,EAKGQ,KALH,CAKS,YAAS;AACdb,QAAAA,aAAa,CAAC,CAACY,aAAa,CAACP,MAAD,CAAd,CAAD,CAAb;AACD,OAPH;AAQD,KAVD,MAUO;AACLL,MAAAA,aAAa,CAAC,CAACY,aAAa,CAACP,MAAD,CAAd,CAAD,CAAb;AACD;AACF,GAfD;AAgBD,CAjBD;;IAmBaS,yBAAb,GAOE,mCAAYC,QAAZ,EAA6B;AAAA,OAN7BA,QAM6B,GANX,CAMW;AAC3B,OAAKA,QAAL,GAAgBA,QAAhB;;AACA,OAAKC,UAAL,GAAkB,UAACC,KAAD;AAAA,WAAkBA,KAAK,IAAIF,QAA3B;AAAA,GAAlB;;AACA,OAAKG,MAAL,GAAcd,YAAY,EAA1B;AACD;;;;"}
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/* eslint-disable @typescript-eslint/restrict-template-expressions */\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 delete record.metadata?.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 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","_record$metadata2","metadataError","metadata","error","Error","symbolicateStackTrace","then","_ref","codeFrame","formatterANSI","catch","ReactNativeConsoleHandler","minLevel","isHandling","level","handle"],"mappings":"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"}
@@ -4,7 +4,8 @@ import parseErrorStack from 'react-native/Libraries/Core/Devtools/parseErrorStac
4
4
  import symbolicateStackTrace from 'react-native/Libraries/Core/Devtools/symbolicateStackTrace';
5
5
 
6
6
  /* eslint-disable @typescript-eslint/no-unsafe-argument */
7
-
7
+ /* eslint-disable @typescript-eslint/no-unsafe-member-access */
8
+ /* eslint-disable @typescript-eslint/restrict-template-expressions */
8
9
  const getStackTrace = e => {
9
10
  // eslint-disable-next-line no-prototype-builtins
10
11
  if (Platform.hasOwnProperty('constants')) {
@@ -12,34 +13,30 @@ const getStackTrace = e => {
12
13
  if (Platform.constants.reactNativeVersion.minor >= 64) {
13
14
  // RN version >= 0.64 -> Stacktrace as string
14
15
  return parseErrorStack(e.stack);
15
- } // RN version == 0.63 -> Stacktrace as string
16
+ }
17
+ // RN version == 0.63 -> Stacktrace as string
16
18
  else return parseErrorStack(e);
17
- } // RN version < 0.63 -> Stacktrace as string
19
+ }
20
+ // RN version < 0.63 -> Stacktrace as string
18
21
  else return parseErrorStack(e);
19
22
  };
20
-
21
23
  function parsedStackToString(stack) {
22
24
  return stack.map(frame => ` at ${frame.file}${frame.lineNumber ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}` : ''}${frame.methodName ? ` in ${frame.methodName}` : ''}`).join('\n');
23
25
  }
24
-
25
26
  function consoleOutput(param) {
26
27
  // eslint-disable-next-line no-console
27
28
  console.log(...param);
28
29
  }
29
-
30
30
  const createHandle = () => {
31
31
  return record => {
32
- var _record$metadata, _record$metadata2;
33
-
34
- const error = (_record$metadata = record.metadata) === null || _record$metadata === void 0 ? void 0 : _record$metadata.error;
35
-
36
- if (error && error instanceof Error) {
37
- (_record$metadata2 = record.metadata) === null || _record$metadata2 === void 0 ? true : delete _record$metadata2.error;
38
- symbolicateStackTrace(getStackTrace(error)).then(({
32
+ const metadataError = record.metadata?.error;
33
+ if (metadataError && metadataError instanceof Error) {
34
+ delete record.metadata?.error;
35
+ symbolicateStackTrace(getStackTrace(metadataError)).then(({
39
36
  stack,
40
37
  codeFrame
41
38
  }) => {
42
- error.stack = parsedStackToString(stack);
39
+ metadataError.stack = parsedStackToString(stack);
43
40
  consoleOutput([formatterANSI(record)]);
44
41
  }).catch(() => {
45
42
  consoleOutput([formatterANSI(record)]);
@@ -49,18 +46,13 @@ const createHandle = () => {
49
46
  }
50
47
  };
51
48
  };
52
-
53
49
  class ReactNativeConsoleHandler {
54
50
  minLevel = 0;
55
-
56
51
  constructor(minLevel) {
57
52
  this.minLevel = minLevel;
58
-
59
53
  this.isHandling = level => level >= minLevel;
60
-
61
54
  this.handle = createHandle();
62
55
  }
63
-
64
56
  }
65
57
 
66
58
  export { ReactNativeConsoleHandler };
@@ -1 +1 @@
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/* eslint-disable @typescript-eslint/restrict-template-expressions */\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 error = record.metadata?.error;\n if (error && error instanceof Error) {\n delete record.metadata?.error;\n symbolicateStackTrace(getStackTrace(error))\n .then(({ stack, codeFrame }: any) => {\n error.stack = parsedStackToString(stack);\n consoleOutput([formatterANSI(record)], record);\n })\n .catch((err) => {\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","error","metadata","Error","symbolicateStackTrace","then","codeFrame","formatterANSI","catch","ReactNativeConsoleHandler","minLevel","constructor","isHandling","level","handle"],"mappings":";;;;;AAAA;;AAgBA,MAAMA,aAAa,GAAIC,CAAD,IAAmB;AACvC;AACA,MAAIC,QAAQ,CAACC,cAAT,CAAwB,WAAxB,CAAJ,EAA0C;AACxC;AACA,QAAID,QAAQ,CAACE,SAAT,CAAmBC,kBAAnB,CAAsCC,KAAtC,IAA+C,EAAnD,EAAuD;AACrD;AACA,aAAOC,eAAe,CAACN,CAAC,CAACO,KAAH,CAAtB;AACD,KAHD;AAAA,SAKK,OAAOD,eAAe,CAACN,CAAD,CAAtB;AACN,GARD;AAAA,OAUK,OAAOM,eAAe,CAACN,CAAD,CAAtB;AACN,CAbD;;AAeA,SAASQ,mBAAT,CAA6BD,KAA7B,EAAmD;AACjD,SAAOA,KAAK,CACTE,GADI,CAEFC,KAAD,IACG,QAAOA,KAAK,CAACC,IAAK,GACjBD,KAAK,CAACE,UAAN,GACK,IAAGF,KAAK,CAACE,UAAW,GAAEF,KAAK,CAACG,MAAN,GAAgB,IAAGH,KAAK,CAACG,MAAO,EAAhC,GAAoC,EAAG,EADlE,GAEI,EACL,GAAEH,KAAK,CAACI,UAAN,GAAoB,OAAMJ,KAAK,CAACI,UAAW,EAA3C,GAA+C,EAAG,EAPpD,EASJC,IATI,CASC,IATD,CAAP;AAUD;;AAED,SAASC,aAAT,CACEC,KADF,EAGQ;AACN;AACAC,EAAAA,OAAO,CAACC,GAAR,CAAY,GAAGF,KAAf;AACD;;AAED,MAAMG,YAAY,GAAG,MAAc;AACjC,SAA4BC,MAArB,IAAoD;AAAA;;AACzD,UAAMC,KAAK,uBAAGD,MAAM,CAACE,QAAV,qDAAG,iBAAiBD,KAA/B;;AACA,QAAIA,KAAK,IAAIA,KAAK,YAAYE,KAA9B,EAAqC;AACnC,2BAAOH,MAAM,CAACE,QAAd,2DAAO,kBAAiBD,KAAxB;AACAG,MAAAA,qBAAqB,CAAC1B,aAAa,CAACuB,KAAD,CAAd,CAArB,CACGI,IADH,CACQ,CAAC;AAAEnB,QAAAA,KAAF;AAASoB,QAAAA;AAAT,OAAD,KAA+B;AACnCL,QAAAA,KAAK,CAACf,KAAN,GAAcC,mBAAmB,CAACD,KAAD,CAAjC;AACAS,QAAAA,aAAa,CAAC,CAACY,aAAa,CAACP,MAAD,CAAd,CAAD,CAAb;AACD,OAJH,EAKGQ,KALH,CAKS,MAAS;AACdb,QAAAA,aAAa,CAAC,CAACY,aAAa,CAACP,MAAD,CAAd,CAAD,CAAb;AACD,OAPH;AAQD,KAVD,MAUO;AACLL,MAAAA,aAAa,CAAC,CAACY,aAAa,CAACP,MAAD,CAAd,CAAD,CAAb;AACD;AACF,GAfD;AAgBD,CAjBD;;AAmBO,MAAMS,yBAAN,CAAmD;AACxDC,EAAAA,QAAQ,GAAU,CAAV;;AAMRC,EAAAA,WAAW,CAACD,QAAD,EAAkB;AAC3B,SAAKA,QAAL,GAAgBA,QAAhB;;AACA,SAAKE,UAAL,GAAmBC,KAAD,IAAkBA,KAAK,IAAIH,QAA7C;;AACA,SAAKI,MAAL,GAAcf,YAAY,EAA1B;AACD;;AAXuD;;;;"}
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/* eslint-disable @typescript-eslint/restrict-template-expressions */\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 delete record.metadata?.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 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","ReactNativeConsoleHandler","minLevel","constructor","isHandling","level","handle"],"mappings":";;;;;AAAA;AACA;AACA;AAcA,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;AACnD,MAAA,OAAOJ,MAAM,CAACE,QAAQ,EAAEC,KAAK,CAAA;MAC7BE,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;QAChBd,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,MAAMU,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,GAAGhB,YAAY,EAAE,CAAA;AAC9B,GAAA;AACF;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nightingale-react-native-console",
3
- "version": "12.1.4",
3
+ "version": "14.0.0",
4
4
  "description": "React Native and Expo handler for nightingale",
5
5
  "keywords": [
6
6
  "nightingale",
@@ -17,14 +17,19 @@
17
17
  },
18
18
  "homepage": "https://github.com/christophehurpeau/nightingale",
19
19
  "type": "module",
20
- "browserslist": [
21
- "defaults",
22
- "> 0.2%",
23
- "not ie < 12",
24
- "not safari < 10",
25
- "not ios_saf < 10"
26
- ],
27
- "types": "./dist/index.d.ts",
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
+ ]
31
+ },
32
+ "types": "./dist/definitions/index.d.ts",
28
33
  "module": "./dist/index-browser.es.js",
29
34
  "browser": "./dist/index-browser.es.js",
30
35
  "exports": {
@@ -38,35 +43,25 @@
38
43
  }
39
44
  }
40
45
  },
41
- "module:modern-browsers": "./dist/index-browsermodern.es.js",
42
46
  "sideEffects": false,
43
47
  "scripts": {
44
- "build": "pob-build && yarn run build:definitions",
45
- "build:definitions": "tsc -p tsconfig.build.json",
46
- "clean": "rm -Rf dist",
48
+ "build": "yarn clean:build && rollup --config rollup.config.mjs && yarn run build:definitions",
49
+ "build:definitions": "tsc -p tsconfig.json",
50
+ "clean": "yarn clean:build",
51
+ "clean:build": "pob-babel-clean-out dist",
47
52
  "lint": "yarn run lint:eslint",
48
- "lint:eslint": "cd ../.. && yarn run eslint --report-unused-disable-directives --resolve-plugins-relative-to . --quiet packages/nightingale-react-native-console",
49
- "watch": "pob-watch"
50
- },
51
- "prettier": {
52
- "trailingComma": "all",
53
- "singleQuote": true,
54
- "arrowParens": "always"
53
+ "lint:eslint": "yarn ../.. run eslint --report-unused-disable-directives --resolve-plugins-relative-to . --quiet packages/nightingale-react-native-console",
54
+ "watch": "yarn clean:build && rollup --config rollup.config.mjs --watch"
55
55
  },
56
+ "prettier": "@pob/root/prettier-config",
56
57
  "pob": {
57
58
  "babelEnvs": [
58
59
  {
59
60
  "target": "browser",
60
- "version": "modern",
61
- "formats": [
62
- "es"
63
- ]
61
+ "version": "modern"
64
62
  },
65
63
  {
66
- "target": "browser",
67
- "formats": [
68
- "es"
69
- ]
64
+ "target": "browser"
70
65
  }
71
66
  ],
72
67
  "entries": [
@@ -77,18 +72,16 @@
77
72
  "react-native": "*"
78
73
  },
79
74
  "dependencies": {
80
- "nightingale-ansi-formatter": "12.1.4",
81
- "nightingale-types": "12.1.4"
75
+ "nightingale-ansi-formatter": "14.0.0",
76
+ "nightingale-types": "14.0.0"
82
77
  },
83
78
  "devDependencies": {
84
- "@babel/core": "7.17.0",
85
- "@babel/preset-env": "7.16.11",
86
- "@types/react-native": "0.66.15",
87
- "babel-preset-modern-browsers": "15.0.2",
88
- "pob-babel": "30.0.1",
89
- "react": "17.0.2",
90
- "react-native": "0.67.2",
91
- "typescript": "4.5.5"
79
+ "@babel/core": "7.22.5",
80
+ "@babel/preset-env": "7.22.5",
81
+ "pob-babel": "36.1.0",
82
+ "react": "18.2.0",
83
+ "react-native": "0.72.0",
84
+ "typescript": "5.1.6"
92
85
  },
93
- "gitHead": "3754d4575d948b5bb8c5227d3c3f4ca25e801db5"
86
+ "gitHead": "bc20e0f093a4fecd4d87f9374f6dbc375c09c25e"
94
87
  }
package/src/index.ts CHANGED
@@ -43,7 +43,7 @@ function parsedStackToString(stack: any[]): string {
43
43
  }
44
44
 
45
45
  function consoleOutput<T extends Metadata>(
46
- param: string | string[],
46
+ param: string[] | string,
47
47
  record: LogRecord<T>,
48
48
  ): void {
49
49
  // eslint-disable-next-line no-console
@@ -52,15 +52,15 @@ function consoleOutput<T extends Metadata>(
52
52
 
53
53
  const createHandle = (): Handle => {
54
54
  return <T extends Metadata>(record: LogRecord<T>): void => {
55
- const error = record.metadata?.error;
56
- if (error && error instanceof Error) {
55
+ const metadataError = record.metadata?.error;
56
+ if (metadataError && metadataError instanceof Error) {
57
57
  delete record.metadata?.error;
58
- symbolicateStackTrace(getStackTrace(error))
58
+ symbolicateStackTrace(getStackTrace(metadataError))
59
59
  .then(({ stack, codeFrame }: any) => {
60
- error.stack = parsedStackToString(stack);
60
+ metadataError.stack = parsedStackToString(stack);
61
61
  consoleOutput([formatterANSI(record)], record);
62
62
  })
63
- .catch((err) => {
63
+ .catch((error) => {
64
64
  consoleOutput([formatterANSI(record)], record);
65
65
  });
66
66
  } else {
@@ -1 +0,0 @@
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"}
package/rollup.config.mjs DELETED
@@ -1,3 +0,0 @@
1
- import createRollupConfig from 'pob-babel/createRollupConfig.js';
2
-
3
- export default createRollupConfig({});
File without changes