nightingale-react-native-console 11.7.4 → 12.1.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 +43 -0
- package/README.md +3 -1
- package/dist/index-browser.es.js +41 -1
- package/dist/index-browser.es.js.map +1 -1
- package/dist/index-browsermodern.es.js +42 -2
- package/dist/index-browsermodern.es.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/package.json +13 -17
- package/src/.eslintrc.json +18 -1
- package/src/index.ts +48 -1
- package/dist/index-browser-dev.es.js +0 -28
- package/dist/index-browser-dev.es.js.map +0 -1
- package/dist/index-browsermodern-dev.es.js +0 -27
- package/dist/index-browsermodern-dev.es.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,49 @@
|
|
|
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
|
+
# [12.1.0](https://github.com/christophehurpeau/nightingale/compare/v12.0.1...v12.1.0) (2021-12-15)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package nightingale-react-native-console
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
## [12.0.1](https://github.com/christophehurpeau/nightingale/compare/v12.0.0...v12.0.1) (2021-12-12)
|
|
15
|
+
|
|
16
|
+
**Note:** Version bump only for package nightingale-react-native-console
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
# [12.0.0](https://github.com/christophehurpeau/nightingale/compare/v11.9.0...v12.0.0) (2021-12-11)
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
### Build System
|
|
26
|
+
|
|
27
|
+
* node 14 and remove dev builds ([432ecd1](https://github.com/christophehurpeau/nightingale/commit/432ecd1faafd0419f57dea00fce560e4cccc207f))
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
### BREAKING CHANGES
|
|
31
|
+
|
|
32
|
+
* requires node 14
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
# [11.9.0](https://github.com/christophehurpeau/nightingale/compare/v11.8.1...v11.9.0) (2021-11-28)
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
### Features
|
|
42
|
+
|
|
43
|
+
* **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)
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
|
|
6
49
|
## [11.7.4](https://github.com/christophehurpeau/nightingale/compare/v11.7.3...v11.7.4) (2021-11-27)
|
|
7
50
|
|
|
8
51
|
|
package/README.md
CHANGED
|
@@ -18,9 +18,11 @@ 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
|
-
import ReactNativeConsoleHandler from 'nightingale-react-native-console';
|
|
25
|
+
import { ReactNativeConsoleHandler } from 'nightingale-react-native-console';
|
|
24
26
|
|
|
25
27
|
configure(
|
|
26
28
|
process.env.NODE_ENV === 'production'
|
package/dist/index-browser.es.js
CHANGED
|
@@ -1,4 +1,28 @@
|
|
|
1
1
|
import formatterANSI from 'nightingale-ansi-formatter';
|
|
2
|
+
import { Platform } from 'react-native';
|
|
3
|
+
import parseErrorStack from 'react-native/Libraries/Core/Devtools/parseErrorStack';
|
|
4
|
+
import symbolicateStackTrace from 'react-native/Libraries/Core/Devtools/symbolicateStackTrace';
|
|
5
|
+
|
|
6
|
+
/* eslint-disable @typescript-eslint/no-unsafe-argument */
|
|
7
|
+
|
|
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
|
+
}
|
|
2
26
|
|
|
3
27
|
function consoleOutput(param) {
|
|
4
28
|
var _console;
|
|
@@ -9,7 +33,23 @@ function consoleOutput(param) {
|
|
|
9
33
|
|
|
10
34
|
var createHandle = function createHandle() {
|
|
11
35
|
return function (record) {
|
|
12
|
-
|
|
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
|
+
}
|
|
13
53
|
};
|
|
14
54
|
};
|
|
15
55
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index-browser.es.js","sources":["../src/index.ts"],"sourcesContent":["
|
|
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,4 +1,26 @@
|
|
|
1
1
|
import formatterANSI from 'nightingale-ansi-formatter';
|
|
2
|
+
import { Platform } from 'react-native';
|
|
3
|
+
import parseErrorStack from 'react-native/Libraries/Core/Devtools/parseErrorStack';
|
|
4
|
+
import symbolicateStackTrace from 'react-native/Libraries/Core/Devtools/symbolicateStackTrace';
|
|
5
|
+
|
|
6
|
+
/* eslint-disable @typescript-eslint/no-unsafe-argument */
|
|
7
|
+
|
|
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
|
+
}
|
|
2
24
|
|
|
3
25
|
function consoleOutput(param) {
|
|
4
26
|
// eslint-disable-next-line no-console
|
|
@@ -7,13 +29,31 @@ function consoleOutput(param) {
|
|
|
7
29
|
|
|
8
30
|
const createHandle = () => {
|
|
9
31
|
return record => {
|
|
10
|
-
|
|
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
|
+
}
|
|
11
50
|
};
|
|
12
51
|
};
|
|
13
52
|
|
|
14
53
|
class ReactNativeConsoleHandler {
|
|
54
|
+
minLevel = 0;
|
|
55
|
+
|
|
15
56
|
constructor(minLevel) {
|
|
16
|
-
this.minLevel = 0;
|
|
17
57
|
this.minLevel = minLevel;
|
|
18
58
|
|
|
19
59
|
this.isHandling = level => level >= minLevel;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index-browsermodern.es.js","sources":["../src/index.ts"],"sourcesContent":["
|
|
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;;;;"}
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
|
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": "
|
|
3
|
+
"version": "12.1.0",
|
|
4
4
|
"description": "React Native and Expo handler for nightingale",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"nightingale",
|
|
@@ -32,27 +32,18 @@
|
|
|
32
32
|
".": {
|
|
33
33
|
"browser": {
|
|
34
34
|
"browser:modern": {
|
|
35
|
-
"development": {
|
|
36
|
-
"import": "./dist/index-browsermodern-dev.es.js"
|
|
37
|
-
},
|
|
38
35
|
"import": "./dist/index-browsermodern.es.js"
|
|
39
36
|
},
|
|
40
|
-
"development": {
|
|
41
|
-
"import": "./dist/index-browser-dev.es.js"
|
|
42
|
-
},
|
|
43
37
|
"import": "./dist/index-browser.es.js"
|
|
44
38
|
}
|
|
45
39
|
}
|
|
46
40
|
},
|
|
47
|
-
"module:browser": "./dist/index-browser.es.js",
|
|
48
|
-
"module:browser-dev": "./dist/index-browser-dev.es.js",
|
|
49
41
|
"module:modern-browsers": "./dist/index-browsermodern.es.js",
|
|
50
|
-
"module:modern-browsers-dev": "./dist/index-browsermodern-dev.es.js",
|
|
51
42
|
"sideEffects": false,
|
|
52
43
|
"scripts": {
|
|
53
44
|
"build": "pob-build && yarn run build:definitions",
|
|
54
45
|
"build:definitions": "tsc -p tsconfig.build.json",
|
|
55
|
-
"clean": "rm -Rf
|
|
46
|
+
"clean": "rm -Rf dist",
|
|
56
47
|
"lint": "yarn run lint:eslint",
|
|
57
48
|
"lint:eslint": "cd ../.. && yarn run eslint --report-unused-disable-directives --resolve-plugins-relative-to . --quiet packages/nightingale-react-native-console",
|
|
58
49
|
"watch": "pob-watch"
|
|
@@ -82,17 +73,22 @@
|
|
|
82
73
|
"index"
|
|
83
74
|
]
|
|
84
75
|
},
|
|
76
|
+
"peerDependencies": {
|
|
77
|
+
"react-native": "*"
|
|
78
|
+
},
|
|
85
79
|
"dependencies": {
|
|
86
|
-
"nightingale-ansi-formatter": "
|
|
87
|
-
"nightingale-types": "
|
|
80
|
+
"nightingale-ansi-formatter": "12.1.0",
|
|
81
|
+
"nightingale-types": "12.1.0"
|
|
88
82
|
},
|
|
89
83
|
"devDependencies": {
|
|
90
84
|
"@babel/core": "7.16.0",
|
|
91
85
|
"@babel/preset-env": "7.16.4",
|
|
86
|
+
"@types/react-native": "0.66.9",
|
|
92
87
|
"babel-preset-modern-browsers": "15.0.2",
|
|
93
|
-
"pob-babel": "
|
|
94
|
-
"
|
|
95
|
-
"
|
|
88
|
+
"pob-babel": "29.4.2",
|
|
89
|
+
"react": "17.0.2",
|
|
90
|
+
"react-native": "0.66.4",
|
|
91
|
+
"typescript": "4.5.4"
|
|
96
92
|
},
|
|
97
|
-
"gitHead": "
|
|
93
|
+
"gitHead": "f2f75856d32f444f0ed08b5ab903537cb1f4c38f"
|
|
98
94
|
}
|
package/src/.eslintrc.json
CHANGED
|
@@ -6,5 +6,22 @@
|
|
|
6
6
|
},
|
|
7
7
|
"plugins": ["@typescript-eslint"],
|
|
8
8
|
"extends": ["@pob/eslint-config-typescript"],
|
|
9
|
-
"ignorePatterns": ["*.d.ts"]
|
|
9
|
+
"ignorePatterns": ["*.d.ts"],
|
|
10
|
+
"overrides": [
|
|
11
|
+
{
|
|
12
|
+
"files": ["**/*.test.ts", "__tests__/**/*.ts"],
|
|
13
|
+
"extends": ["@pob/eslint-config-typescript/test"],
|
|
14
|
+
"env": {
|
|
15
|
+
"jest": true
|
|
16
|
+
},
|
|
17
|
+
"rules": {
|
|
18
|
+
"import/no-extraneous-dependencies": [
|
|
19
|
+
"error",
|
|
20
|
+
{
|
|
21
|
+
"devDependencies": true
|
|
22
|
+
}
|
|
23
|
+
]
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
]
|
|
10
27
|
}
|
package/src/index.ts
CHANGED
|
@@ -1,3 +1,6 @@
|
|
|
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
5
|
import type {
|
|
3
6
|
Level,
|
|
@@ -7,6 +10,37 @@ import type {
|
|
|
7
10
|
Metadata,
|
|
8
11
|
Handler,
|
|
9
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
|
+
}
|
|
10
44
|
|
|
11
45
|
function consoleOutput<T extends Metadata>(
|
|
12
46
|
param: string | string[],
|
|
@@ -18,7 +52,20 @@ function consoleOutput<T extends Metadata>(
|
|
|
18
52
|
|
|
19
53
|
const createHandle = (): Handle => {
|
|
20
54
|
return <T extends Metadata>(record: LogRecord<T>): void => {
|
|
21
|
-
|
|
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
|
+
}
|
|
22
69
|
};
|
|
23
70
|
};
|
|
24
71
|
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import formatterANSI from 'nightingale-ansi-formatter';
|
|
2
|
-
|
|
3
|
-
function consoleOutput(param) {
|
|
4
|
-
var _console;
|
|
5
|
-
|
|
6
|
-
// eslint-disable-next-line no-console
|
|
7
|
-
(_console = console).log.apply(_console, param);
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
var createHandle = function createHandle() {
|
|
11
|
-
return function (record) {
|
|
12
|
-
consoleOutput([formatterANSI(record)]);
|
|
13
|
-
};
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
var ReactNativeConsoleHandler = function ReactNativeConsoleHandler(minLevel) {
|
|
17
|
-
this.minLevel = 0;
|
|
18
|
-
this.minLevel = minLevel;
|
|
19
|
-
|
|
20
|
-
this.isHandling = function (level) {
|
|
21
|
-
return level >= minLevel;
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
this.handle = createHandle();
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
export { ReactNativeConsoleHandler };
|
|
28
|
-
//# sourceMappingURL=index-browser-dev.es.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-browser-dev.es.js","sources":["../src/index.ts"],"sourcesContent":["import formatterANSI from 'nightingale-ansi-formatter';\nimport type {\n Level,\n Handle,\n IsHandling,\n LogRecord,\n Metadata,\n Handler,\n} from 'nightingale-types';\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 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":["consoleOutput","param","console","log","createHandle","record","formatterANSI","ReactNativeConsoleHandler","minLevel","isHandling","level","handle"],"mappings":";;AAUA,SAASA,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;AACzDL,IAAAA,aAAa,CAAC,CAACM,aAAa,CAACD,MAAD,CAAd,CAAD,CAAb;AACD,GAFD;AAGD,CAJD;;IAMaE,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,GAAcP,YAAY,EAA1B;AACD;;;;"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import formatterANSI from 'nightingale-ansi-formatter';
|
|
2
|
-
|
|
3
|
-
function consoleOutput(param) {
|
|
4
|
-
// eslint-disable-next-line no-console
|
|
5
|
-
console.log(...param);
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
const createHandle = () => {
|
|
9
|
-
return record => {
|
|
10
|
-
consoleOutput([formatterANSI(record)]);
|
|
11
|
-
};
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
class ReactNativeConsoleHandler {
|
|
15
|
-
constructor(minLevel) {
|
|
16
|
-
this.minLevel = 0;
|
|
17
|
-
this.minLevel = minLevel;
|
|
18
|
-
|
|
19
|
-
this.isHandling = level => level >= minLevel;
|
|
20
|
-
|
|
21
|
-
this.handle = createHandle();
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
export { ReactNativeConsoleHandler };
|
|
27
|
-
//# sourceMappingURL=index-browsermodern-dev.es.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-browsermodern-dev.es.js","sources":["../src/index.ts"],"sourcesContent":["import formatterANSI from 'nightingale-ansi-formatter';\nimport type {\n Level,\n Handle,\n IsHandling,\n LogRecord,\n Metadata,\n Handler,\n} from 'nightingale-types';\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 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":["consoleOutput","param","console","log","createHandle","record","formatterANSI","ReactNativeConsoleHandler","constructor","minLevel","isHandling","level","handle"],"mappings":";;AAUA,SAASA,aAAT,CACEC,KADF,EAGQ;AACN;AACAC,EAAAA,OAAO,CAACC,GAAR,CAAY,GAAGF,KAAf;AACD;;AAED,MAAMG,YAAY,GAAG,MAAc;AACjC,SAA4BC,MAArB,IAAoD;AACzDL,IAAAA,aAAa,CAAC,CAACM,aAAa,CAACD,MAAD,CAAd,CAAD,CAAb;AACD,GAFD;AAGD,CAJD;;AAMO,MAAME,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,GAAcR,YAAY,EAA1B;AACD;;AAXuD;;;;"}
|