nightingale-react-native-console 11.7.1 → 11.9.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/.eslintrc.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "root": true,
3
- "extends": ["@pob/eslint-config/root", "@pob/eslint-config-node"],
3
+ "extends": ["@pob/eslint-config/root-commonjs"],
4
4
  "env": {
5
5
  "browser": true
6
6
  },
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
+ # [11.9.0](https://github.com/christophehurpeau/nightingale/compare/v11.8.1...v11.9.0) (2021-11-28)
7
+
8
+
9
+ ### Features
10
+
11
+ * **nightingale-react-native-console:** parse stack trace using react-native tools ([79c0c9e](https://github.com/christophehurpeau/nightingale/commit/79c0c9ee956af5459527926cbaf33995ea3ac088)), closes [#242](https://github.com/christophehurpeau/nightingale/issues/242)
12
+
13
+
14
+
15
+
16
+
17
+ ## [11.7.4](https://github.com/christophehurpeau/nightingale/compare/v11.7.3...v11.7.4) (2021-11-27)
18
+
19
+
20
+ ### Bug Fixes
21
+
22
+ * build all packages ([dbb4785](https://github.com/christophehurpeau/nightingale/commit/dbb4785cbb8c75942935c4a5935df32fd2e93690))
23
+
24
+
25
+
26
+
27
+
28
+ ## [11.7.3](https://github.com/christophehurpeau/nightingale/compare/v11.7.2...v11.7.3) (2021-11-27)
29
+
30
+
31
+ ### Bug Fixes
32
+
33
+ * **nightingale-react-native-console:** always use console.log ([ad93004](https://github.com/christophehurpeau/nightingale/commit/ad93004db380994a0e378d57a67e64414e02b9bf)), closes [#241](https://github.com/christophehurpeau/nightingale/issues/241)
34
+
35
+
36
+
37
+
38
+
39
+ ## [11.7.2](https://github.com/christophehurpeau/nightingale/compare/v11.7.1...v11.7.2) (2021-11-27)
40
+
41
+ **Note:** Version bump only for package nightingale-react-native-console
42
+
43
+
44
+
45
+
46
+
6
47
  ## [11.7.1](https://github.com/christophehurpeau/nightingale/compare/v11.7.0...v11.7.1) (2021-06-29)
7
48
 
8
49
 
package/README.md CHANGED
@@ -18,6 +18,8 @@ npm install --save nightingale nightingale-react-native-console
18
18
 
19
19
  ## Usage
20
20
 
21
+ :warn: This logger is meant for dev only.
22
+
21
23
  ```js
22
24
  import { configure, Level } from 'nightingale';
23
25
  import ReactNativeConsoleHandler from 'nightingale-react-native-console';
@@ -1,9 +1,55 @@
1
1
  import formatterANSI from 'nightingale-ansi-formatter';
2
- import consoleOutput from 'nightingale-console-output';
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
+
8
+ var getStackTrace = function getStackTrace(e) {
9
+ // eslint-disable-next-line no-prototype-builtins
10
+ if (Platform.hasOwnProperty('constants')) {
11
+ // RN version >= 0.63
12
+ if (Platform.constants.reactNativeVersion.minor >= 64) {
13
+ // RN version >= 0.64 -> Stacktrace as string
14
+ return parseErrorStack(e.stack);
15
+ } // RN version == 0.63 -> Stacktrace as string
16
+ else return parseErrorStack(e);
17
+ } // RN version < 0.63 -> Stacktrace as string
18
+ else return parseErrorStack(e);
19
+ };
20
+
21
+ function parsedStackToString(stack) {
22
+ return stack.map(function (frame) {
23
+ return ` at ${frame.file}${frame.lineNumber ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}` : ''}${frame.methodName ? ` in ${frame.methodName}` : ''}`;
24
+ }).join('\n');
25
+ }
26
+
27
+ function consoleOutput(param) {
28
+ var _console;
29
+
30
+ // eslint-disable-next-line no-console
31
+ (_console = console).log.apply(_console, param);
32
+ }
3
33
 
4
34
  var createHandle = function createHandle() {
5
35
  return function (record) {
6
- return consoleOutput([formatterANSI(record)], record);
36
+ 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) {
41
+ (_record$metadata2 = record.metadata) == null ? true : delete _record$metadata2.error;
42
+ symbolicateStackTrace(getStackTrace(error)).then(function (_ref) {
43
+ var stack = _ref.stack;
44
+ _ref.codeFrame;
45
+ error.stack = parsedStackToString(stack);
46
+ consoleOutput([formatterANSI(record)]);
47
+ }).catch(function () {
48
+ consoleOutput([formatterANSI(record)]);
49
+ });
50
+ } else {
51
+ consoleOutput([formatterANSI(record)]);
52
+ }
7
53
  };
8
54
  };
9
55
 
@@ -1 +1 @@
1
- {"version":3,"file":"index-browser-dev.es.js","sources":["../src/index.ts"],"sourcesContent":["import formatterANSI from 'nightingale-ansi-formatter';\nimport consoleOutput from 'nightingale-console-output';\nimport type {\n Level,\n Handle,\n IsHandling,\n LogRecord,\n Metadata,\n Handler,\n} from 'nightingale-types';\n\nconst createHandle = (): Handle => {\n return <T extends Metadata>(record: LogRecord<T>): void => {\n return consoleOutput([formatterANSI(record)], record);\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":["createHandle","record","consoleOutput","formatterANSI","ReactNativeConsoleHandler","minLevel","isHandling","level","handle"],"mappings":";;;AAWA,IAAMA,YAAY,GAAG,SAAfA,YAAe,GAAc;AACjC,SAAO,UAAqBC,MAArB,EAAoD;AACzD,WAAOC,aAAa,CAAC,CAACC,aAAa,CAACF,MAAD,CAAd,CAAD,EAA0BA,MAA1B,CAApB;AACD,GAFD;AAGD,CAJD;;IAMaG,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,GAAcR,YAAY,EAA1B;AACD;;;;"}
1
+ {"version":3,"file":"index-browser-dev.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,WACG,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,EALvD;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,9 +1,55 @@
1
1
  import formatterANSI from 'nightingale-ansi-formatter';
2
- import consoleOutput from 'nightingale-console-output';
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
+
8
+ var getStackTrace = function getStackTrace(e) {
9
+ // eslint-disable-next-line no-prototype-builtins
10
+ if (Platform.hasOwnProperty('constants')) {
11
+ // RN version >= 0.63
12
+ if (Platform.constants.reactNativeVersion.minor >= 64) {
13
+ // RN version >= 0.64 -> Stacktrace as string
14
+ return parseErrorStack(e.stack);
15
+ } // RN version == 0.63 -> Stacktrace as string
16
+ else return parseErrorStack(e);
17
+ } // RN version < 0.63 -> Stacktrace as string
18
+ else return parseErrorStack(e);
19
+ };
20
+
21
+ function parsedStackToString(stack) {
22
+ return stack.map(function (frame) {
23
+ return ` at ${frame.file}${frame.lineNumber ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}` : ''}${frame.methodName ? ` in ${frame.methodName}` : ''}`;
24
+ }).join('\n');
25
+ }
26
+
27
+ function consoleOutput(param) {
28
+ var _console;
29
+
30
+ // eslint-disable-next-line no-console
31
+ (_console = console).log.apply(_console, param);
32
+ }
3
33
 
4
34
  var createHandle = function createHandle() {
5
35
  return function (record) {
6
- return consoleOutput([formatterANSI(record)], record);
36
+ 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) {
41
+ (_record$metadata2 = record.metadata) == null ? true : delete _record$metadata2.error;
42
+ symbolicateStackTrace(getStackTrace(error)).then(function (_ref) {
43
+ var stack = _ref.stack;
44
+ _ref.codeFrame;
45
+ error.stack = parsedStackToString(stack);
46
+ consoleOutput([formatterANSI(record)]);
47
+ }).catch(function () {
48
+ consoleOutput([formatterANSI(record)]);
49
+ });
50
+ } else {
51
+ consoleOutput([formatterANSI(record)]);
52
+ }
7
53
  };
8
54
  };
9
55
 
@@ -1 +1 @@
1
- {"version":3,"file":"index-browser.es.js","sources":["../src/index.ts"],"sourcesContent":["import formatterANSI from 'nightingale-ansi-formatter';\nimport consoleOutput from 'nightingale-console-output';\nimport type {\n Level,\n Handle,\n IsHandling,\n LogRecord,\n Metadata,\n Handler,\n} from 'nightingale-types';\n\nconst createHandle = (): Handle => {\n return <T extends Metadata>(record: LogRecord<T>): void => {\n return consoleOutput([formatterANSI(record)], record);\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":["createHandle","record","consoleOutput","formatterANSI","ReactNativeConsoleHandler","minLevel","isHandling","level","handle"],"mappings":";;;AAWA,IAAMA,YAAY,GAAG,SAAfA,YAAe,GAAc;AACjC,SAAO,UAAqBC,MAArB,EAAoD;AACzD,WAAOC,aAAa,CAAC,CAACC,aAAa,CAACF,MAAD,CAAd,CAAD,EAA0BA,MAA1B,CAApB;AACD,GAFD;AAGD,CAJD;;IAMaG,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,GAAcR,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 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,WACG,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,EALvD;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,9 +1,52 @@
1
1
  import formatterANSI from 'nightingale-ansi-formatter';
2
- import consoleOutput from 'nightingale-console-output';
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
+
8
+ const getStackTrace = e => {
9
+ // eslint-disable-next-line no-prototype-builtins
10
+ if (Platform.hasOwnProperty('constants')) {
11
+ // RN version >= 0.63
12
+ if (Platform.constants.reactNativeVersion.minor >= 64) {
13
+ // RN version >= 0.64 -> Stacktrace as string
14
+ return parseErrorStack(e.stack);
15
+ } // RN version == 0.63 -> Stacktrace as string
16
+ else return parseErrorStack(e);
17
+ } // RN version < 0.63 -> Stacktrace as string
18
+ else return parseErrorStack(e);
19
+ };
20
+
21
+ function parsedStackToString(stack) {
22
+ return stack.map(frame => ` at ${frame.file}${frame.lineNumber ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}` : ''}${frame.methodName ? ` in ${frame.methodName}` : ''}`).join('\n');
23
+ }
24
+
25
+ function consoleOutput(param) {
26
+ // eslint-disable-next-line no-console
27
+ console.log(...param);
28
+ }
3
29
 
4
30
  const createHandle = () => {
5
31
  return record => {
6
- return consoleOutput([formatterANSI(record)], 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(({
39
+ stack,
40
+ codeFrame
41
+ }) => {
42
+ error.stack = parsedStackToString(stack);
43
+ consoleOutput([formatterANSI(record)]);
44
+ }).catch(() => {
45
+ consoleOutput([formatterANSI(record)]);
46
+ });
47
+ } else {
48
+ consoleOutput([formatterANSI(record)]);
49
+ }
7
50
  };
8
51
  };
9
52
 
@@ -1 +1 @@
1
- {"version":3,"file":"index-browsermodern-dev.es.js","sources":["../src/index.ts"],"sourcesContent":["import formatterANSI from 'nightingale-ansi-formatter';\nimport consoleOutput from 'nightingale-console-output';\nimport type {\n Level,\n Handle,\n IsHandling,\n LogRecord,\n Metadata,\n Handler,\n} from 'nightingale-types';\n\nconst createHandle = (): Handle => {\n return <T extends Metadata>(record: LogRecord<T>): void => {\n return consoleOutput([formatterANSI(record)], record);\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":["createHandle","record","consoleOutput","formatterANSI","ReactNativeConsoleHandler","constructor","minLevel","isHandling","level","handle"],"mappings":";;;AAWA,MAAMA,YAAY,GAAG,MAAc;AACjC,SAA4BC,MAArB,IAAoD;AACzD,WAAOC,aAAa,CAAC,CAACC,aAAa,CAACF,MAAD,CAAd,CAAD,EAA0BA,MAA1B,CAApB;AACD,GAFD;AAGD,CAJD;;AAMO,MAAMG,yBAAN,CAAmD;AAOxDC,EAAAA,WAAW,CAACC,QAAD,EAAkB;AAAA,SAN7BA,QAM6B,GANX,CAMW;AAC3B,SAAKA,QAAL,GAAgBA,QAAhB;;AACA,SAAKC,UAAL,GAAmBC,KAAD,IAAkBA,KAAK,IAAIF,QAA7C;;AACA,SAAKG,MAAL,GAAcT,YAAY,EAA1B;AACD;;AAXuD;;;;"}
1
+ {"version":3,"file":"index-browsermodern-dev.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","constructor","minLevel","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;AAOxDC,EAAAA,WAAW,CAACC,QAAD,EAAkB;AAAA,SAN7BA,QAM6B,GANX,CAMW;AAC3B,SAAKA,QAAL,GAAgBA,QAAhB;;AACA,SAAKC,UAAL,GAAmBC,KAAD,IAAkBA,KAAK,IAAIF,QAA7C;;AACA,SAAKG,MAAL,GAAcf,YAAY,EAA1B;AACD;;AAXuD;;;;"}
@@ -1,9 +1,52 @@
1
1
  import formatterANSI from 'nightingale-ansi-formatter';
2
- import consoleOutput from 'nightingale-console-output';
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
+
8
+ const getStackTrace = e => {
9
+ // eslint-disable-next-line no-prototype-builtins
10
+ if (Platform.hasOwnProperty('constants')) {
11
+ // RN version >= 0.63
12
+ if (Platform.constants.reactNativeVersion.minor >= 64) {
13
+ // RN version >= 0.64 -> Stacktrace as string
14
+ return parseErrorStack(e.stack);
15
+ } // RN version == 0.63 -> Stacktrace as string
16
+ else return parseErrorStack(e);
17
+ } // RN version < 0.63 -> Stacktrace as string
18
+ else return parseErrorStack(e);
19
+ };
20
+
21
+ function parsedStackToString(stack) {
22
+ return stack.map(frame => ` at ${frame.file}${frame.lineNumber ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}` : ''}${frame.methodName ? ` in ${frame.methodName}` : ''}`).join('\n');
23
+ }
24
+
25
+ function consoleOutput(param) {
26
+ // eslint-disable-next-line no-console
27
+ console.log(...param);
28
+ }
3
29
 
4
30
  const createHandle = () => {
5
31
  return record => {
6
- return consoleOutput([formatterANSI(record)], 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(({
39
+ stack,
40
+ codeFrame
41
+ }) => {
42
+ error.stack = parsedStackToString(stack);
43
+ consoleOutput([formatterANSI(record)]);
44
+ }).catch(() => {
45
+ consoleOutput([formatterANSI(record)]);
46
+ });
47
+ } else {
48
+ consoleOutput([formatterANSI(record)]);
49
+ }
7
50
  };
8
51
  };
9
52
 
@@ -1 +1 @@
1
- {"version":3,"file":"index-browsermodern.es.js","sources":["../src/index.ts"],"sourcesContent":["import formatterANSI from 'nightingale-ansi-formatter';\nimport consoleOutput from 'nightingale-console-output';\nimport type {\n Level,\n Handle,\n IsHandling,\n LogRecord,\n Metadata,\n Handler,\n} from 'nightingale-types';\n\nconst createHandle = (): Handle => {\n return <T extends Metadata>(record: LogRecord<T>): void => {\n return consoleOutput([formatterANSI(record)], record);\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":["createHandle","record","consoleOutput","formatterANSI","ReactNativeConsoleHandler","constructor","minLevel","isHandling","level","handle"],"mappings":";;;AAWA,MAAMA,YAAY,GAAG,MAAc;AACjC,SAA4BC,MAArB,IAAoD;AACzD,WAAOC,aAAa,CAAC,CAACC,aAAa,CAACF,MAAD,CAAd,CAAD,EAA0BA,MAA1B,CAApB;AACD,GAFD;AAGD,CAJD;;AAMO,MAAMG,yBAAN,CAAmD;AAOxDC,EAAAA,WAAW,CAACC,QAAD,EAAkB;AAAA,SAN7BA,QAM6B,GANX,CAMW;AAC3B,SAAKA,QAAL,GAAgBA,QAAhB;;AACA,SAAKC,UAAL,GAAmBC,KAAD,IAAkBA,KAAK,IAAIF,QAA7C;;AACA,SAAKG,MAAL,GAAcT,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 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","constructor","minLevel","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;AAOxDC,EAAAA,WAAW,CAACC,QAAD,EAAkB;AAAA,SAN7BA,QAM6B,GANX,CAMW;AAC3B,SAAKA,QAAL,GAAgBA,QAAhB;;AACA,SAAKC,UAAL,GAAmBC,KAAD,IAAkBA,KAAK,IAAIF,QAA7C;;AACA,SAAKG,MAAL,GAAcf,YAAY,EAA1B;AACD;;AAXuD;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,KAAK,EACL,MAAM,EACN,UAAU,EAGV,OAAO,EACR,MAAM,mBAAmB,CAAC;AAQ3B,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":"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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nightingale-react-native-console",
3
- "version": "11.7.1",
3
+ "version": "11.9.0",
4
4
  "description": "React Native and Expo handler for nightingale",
5
5
  "keywords": [
6
6
  "nightingale",
@@ -16,6 +16,7 @@
16
16
  "directory": "packages/nightingale-react-native-console"
17
17
  },
18
18
  "homepage": "https://github.com/christophehurpeau/nightingale",
19
+ "type": "commonjs",
19
20
  "browserslist": [
20
21
  "defaults",
21
22
  "> 0.2%",
@@ -23,11 +24,11 @@
23
24
  "not safari < 10",
24
25
  "not ios_saf < 10"
25
26
  ],
26
- "main": "./dist/index-browser.es.js",
27
27
  "types": "./dist/index.d.ts",
28
28
  "module": "./dist/index-browser.es.js",
29
29
  "browser": "./dist/index-browser.es.js",
30
30
  "exports": {
31
+ "./package.json": "./package.json",
31
32
  ".": {
32
33
  "browser": {
33
34
  "browser:modern": {
@@ -53,7 +54,7 @@
53
54
  "build:definitions": "tsc -p tsconfig.build.json",
54
55
  "clean": "rm -Rf docs dist test/node6 coverage",
55
56
  "lint": "yarn run lint:eslint",
56
- "lint:eslint": "yarn --cwd ../.. run eslint --ext .js,.mjs,.ts --report-unused-disable-directives --quiet packages/nightingale-react-native-console",
57
+ "lint:eslint": "cd ../.. && yarn run eslint --report-unused-disable-directives --resolve-plugins-relative-to . --quiet packages/nightingale-react-native-console",
57
58
  "watch": "pob-watch"
58
59
  },
59
60
  "prettier": {
@@ -81,28 +82,23 @@
81
82
  "index"
82
83
  ]
83
84
  },
85
+ "peerDependencies": {
86
+ "react-native": "*"
87
+ },
84
88
  "dependencies": {
85
- "nightingale-ansi-formatter": "^11.7.1",
86
- "nightingale-console-output": "^11.7.1",
87
- "nightingale-types": "^11.7.1"
89
+ "nightingale-ansi-formatter": "^11.7.4",
90
+ "nightingale-types": "^11.7.4"
88
91
  },
89
92
  "devDependencies": {
90
- "@babel/core": "7.14.6",
91
- "@babel/preset-env": "7.14.7",
92
- "@pob/eslint-config": "43.2.0",
93
- "@pob/eslint-config-node": "43.2.0",
94
- "@pob/eslint-config-typescript": "43.2.0",
95
- "@typescript-eslint/eslint-plugin": "4.28.1",
96
- "@typescript-eslint/parser": "4.28.1",
93
+ "@babel/core": "7.16.0",
94
+ "@babel/preset-env": "7.16.4",
95
+ "@types/react-native": "0.66.6",
97
96
  "babel-preset-modern-browsers": "15.0.2",
98
- "eslint": "7.29.0",
99
- "eslint-import-resolver-node": "0.3.4",
100
- "eslint-plugin-import": "2.23.4",
101
- "eslint-plugin-node": "11.1.0",
102
- "eslint-plugin-unicorn": "29.0.0",
103
- "pob-babel": "27.0.3",
104
- "rollup": "2.52.3",
105
- "typescript": "4.3.4"
97
+ "pob-babel": "28.5.0",
98
+ "react": "17.0.2",
99
+ "react-native": "0.66.3",
100
+ "rollup": "2.60.1",
101
+ "typescript": "4.5.2"
106
102
  },
107
- "gitHead": "325214aa6c7f87ace818389b77ce7b4208005c11"
103
+ "gitHead": "4d2ce31a142c2c4a3b8c5587ce1dc1a827f87bc5"
108
104
  }
@@ -0,0 +1,3 @@
1
+ import createRollupConfig from 'pob-babel/createRollupConfig.js';
2
+
3
+ export default createRollupConfig({});
package/src/index.ts CHANGED
@@ -1,5 +1,7 @@
1
+ /* eslint-disable @typescript-eslint/no-unsafe-argument */
2
+ /* eslint-disable @typescript-eslint/no-unsafe-member-access */
3
+ /* eslint-disable @typescript-eslint/restrict-template-expressions */
1
4
  import formatterANSI from 'nightingale-ansi-formatter';
2
- import consoleOutput from 'nightingale-console-output';
3
5
  import type {
4
6
  Level,
5
7
  Handle,
@@ -8,10 +10,62 @@ import type {
8
10
  Metadata,
9
11
  Handler,
10
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';
16
+
17
+ const getStackTrace = (e: Error): any => {
18
+ // eslint-disable-next-line no-prototype-builtins
19
+ if (Platform.hasOwnProperty('constants')) {
20
+ // RN version >= 0.63
21
+ if (Platform.constants.reactNativeVersion.minor >= 64) {
22
+ // RN version >= 0.64 -> Stacktrace as string
23
+ return parseErrorStack(e.stack as unknown as any);
24
+ }
25
+ // RN version == 0.63 -> Stacktrace as string
26
+ else return parseErrorStack(e);
27
+ }
28
+ // RN version < 0.63 -> Stacktrace as string
29
+ else return parseErrorStack(e);
30
+ };
31
+
32
+ function parsedStackToString(stack: any[]): string {
33
+ return stack
34
+ .map(
35
+ (frame) =>
36
+ ` at ${frame.file}${
37
+ frame.lineNumber
38
+ ? `:${frame.lineNumber}${frame.column ? `:${frame.column}` : ''}`
39
+ : ''
40
+ }${frame.methodName ? ` in ${frame.methodName}` : ''}`,
41
+ )
42
+ .join('\n');
43
+ }
44
+
45
+ function consoleOutput<T extends Metadata>(
46
+ param: string | string[],
47
+ record: LogRecord<T>,
48
+ ): void {
49
+ // eslint-disable-next-line no-console
50
+ console.log(...param);
51
+ }
11
52
 
12
53
  const createHandle = (): Handle => {
13
54
  return <T extends Metadata>(record: LogRecord<T>): void => {
14
- return consoleOutput([formatterANSI(record)], record);
55
+ const error = record.metadata?.error;
56
+ if (error && error instanceof Error) {
57
+ delete record.metadata?.error;
58
+ symbolicateStackTrace(getStackTrace(error))
59
+ .then(({ stack, codeFrame }: any) => {
60
+ error.stack = parsedStackToString(stack);
61
+ consoleOutput([formatterANSI(record)], record);
62
+ })
63
+ .catch((err) => {
64
+ consoleOutput([formatterANSI(record)], record);
65
+ });
66
+ } else {
67
+ consoleOutput([formatterANSI(record)], record);
68
+ }
15
69
  };
16
70
  };
17
71