@formatjs/ts-transformer 3.5.1 → 3.8.1
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/index.js +3 -3
- package/package.json +3 -3
- package/src/console_utils.js +6 -6
- package/src/interpolate-name.js +2 -2
- package/src/transform.js +24 -24
- package/ts-jest-integration.js +1 -1
package/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
var tslib_1 = require("tslib");
|
|
4
|
-
tslib_1.__exportStar(require("./src/transform"), exports);
|
|
5
|
-
tslib_1.__exportStar(require("./src/types"), exports);
|
|
6
|
-
tslib_1.__exportStar(require("./src/interpolate-name"), exports);
|
|
4
|
+
(0, tslib_1.__exportStar)(require("./src/transform"), exports);
|
|
5
|
+
(0, tslib_1.__exportStar)(require("./src/types"), exports);
|
|
6
|
+
(0, tslib_1.__exportStar)(require("./src/interpolate-name"), exports);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@formatjs/ts-transformer",
|
|
3
|
-
"version": "3.
|
|
3
|
+
"version": "3.8.1",
|
|
4
4
|
"description": "TS Compiler transformer for formatjs",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"types": "index.d.ts",
|
|
@@ -17,11 +17,11 @@
|
|
|
17
17
|
"react-intl"
|
|
18
18
|
],
|
|
19
19
|
"dependencies": {
|
|
20
|
-
"@formatjs/icu-messageformat-parser": "2.0.
|
|
20
|
+
"@formatjs/icu-messageformat-parser": "2.0.16",
|
|
21
21
|
"@types/node": "14 || 16",
|
|
22
22
|
"chalk": "^4.0.0",
|
|
23
23
|
"tslib": "^2.1.0",
|
|
24
|
-
"typescript": "^4.
|
|
24
|
+
"typescript": "^4.5"
|
|
25
25
|
},
|
|
26
26
|
"peerDependencies": {
|
|
27
27
|
"ts-jest": "27"
|
package/src/console_utils.js
CHANGED
|
@@ -10,19 +10,19 @@ var LEVEL_COLORS = {
|
|
|
10
10
|
error: chalk_1.red,
|
|
11
11
|
};
|
|
12
12
|
function label(level, message) {
|
|
13
|
-
return "[@formatjs/ts-transformer] ["
|
|
13
|
+
return "[@formatjs/ts-transformer] [".concat(LEVEL_COLORS[level](level.toUpperCase()), "] ").concat(message);
|
|
14
14
|
}
|
|
15
15
|
function debug(message) {
|
|
16
16
|
var args = [];
|
|
17
17
|
for (var _i = 1; _i < arguments.length; _i++) {
|
|
18
18
|
args[_i - 1] = arguments[_i];
|
|
19
19
|
}
|
|
20
|
-
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
21
|
-
return tslib_1.__generator(this, function (_a) {
|
|
20
|
+
return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
|
|
21
|
+
return (0, tslib_1.__generator)(this, function (_a) {
|
|
22
22
|
if (process.env.LOG_LEVEL !== 'debug') {
|
|
23
23
|
return [2 /*return*/];
|
|
24
24
|
}
|
|
25
|
-
console.error(util_1.format.apply(void 0, tslib_1.__spreadArray([label('debug', message)], args)));
|
|
25
|
+
console.error(util_1.format.apply(void 0, (0, tslib_1.__spreadArray)([label('debug', message)], args, false)));
|
|
26
26
|
console.error('\n');
|
|
27
27
|
return [2 /*return*/];
|
|
28
28
|
});
|
|
@@ -34,7 +34,7 @@ function warn(message) {
|
|
|
34
34
|
for (var _i = 1; _i < arguments.length; _i++) {
|
|
35
35
|
args[_i - 1] = arguments[_i];
|
|
36
36
|
}
|
|
37
|
-
console.error(util_1.format.apply(void 0, tslib_1.__spreadArray([label('warn', message)], args)));
|
|
37
|
+
console.error(util_1.format.apply(void 0, (0, tslib_1.__spreadArray)([label('warn', message)], args, false)));
|
|
38
38
|
console.error('\n');
|
|
39
39
|
}
|
|
40
40
|
exports.warn = warn;
|
|
@@ -43,7 +43,7 @@ function error(message) {
|
|
|
43
43
|
for (var _i = 1; _i < arguments.length; _i++) {
|
|
44
44
|
args[_i - 1] = arguments[_i];
|
|
45
45
|
}
|
|
46
|
-
console.error(util_1.format.apply(void 0, tslib_1.__spreadArray([label('error', message)], args)));
|
|
46
|
+
console.error(util_1.format.apply(void 0, (0, tslib_1.__spreadArray)([label('error', message)], args, false)));
|
|
47
47
|
console.error('\n');
|
|
48
48
|
}
|
|
49
49
|
exports.error = error;
|
package/src/interpolate-name.js
CHANGED
|
@@ -2,13 +2,13 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.interpolateName = void 0;
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
|
-
var path = tslib_1.__importStar(require("path"));
|
|
5
|
+
var path = (0, tslib_1.__importStar)(require("path"));
|
|
6
6
|
var crypto_1 = require("crypto");
|
|
7
7
|
function getHashDigest(content, hashType, digestType, length) {
|
|
8
8
|
if (hashType === void 0) { hashType = 'md5'; }
|
|
9
9
|
if (digestType === void 0) { digestType = 'hex'; }
|
|
10
10
|
if (length === void 0) { length = 9999; }
|
|
11
|
-
var hasher = crypto_1.createHash(hashType);
|
|
11
|
+
var hasher = (0, crypto_1.createHash)(hashType);
|
|
12
12
|
hasher.update(content);
|
|
13
13
|
return hasher.digest(digestType).slice(0, length);
|
|
14
14
|
}
|
package/src/transform.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.transform = exports.transformWithTs = void 0;
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
|
-
var typescript = tslib_1.__importStar(require("typescript"));
|
|
5
|
+
var typescript = (0, tslib_1.__importStar)(require("typescript"));
|
|
6
6
|
var interpolate_name_1 = require("./interpolate-name");
|
|
7
7
|
var icu_messageformat_parser_1 = require("@formatjs/icu-messageformat-parser");
|
|
8
8
|
var console_utils_1 = require("./console_utils");
|
|
@@ -24,7 +24,7 @@ function primitiveToTSNode(factory, v) {
|
|
|
24
24
|
}
|
|
25
25
|
function isValidIdentifier(k) {
|
|
26
26
|
try {
|
|
27
|
-
new Function("return {"
|
|
27
|
+
new Function("return {".concat(k, ":1}"));
|
|
28
28
|
return true;
|
|
29
29
|
}
|
|
30
30
|
catch (e) {
|
|
@@ -63,12 +63,12 @@ function isMultipleMessageDecl(ts, node) {
|
|
|
63
63
|
node.expression.text === 'defineMessages');
|
|
64
64
|
}
|
|
65
65
|
function isSingularMessageDecl(ts, node, additionalComponentNames) {
|
|
66
|
-
var compNames = new Set(tslib_1.__spreadArray([
|
|
66
|
+
var compNames = new Set((0, tslib_1.__spreadArray)([
|
|
67
67
|
'FormattedMessage',
|
|
68
68
|
'defineMessage',
|
|
69
69
|
'formatMessage',
|
|
70
70
|
'$formatMessage'
|
|
71
|
-
], additionalComponentNames));
|
|
71
|
+
], additionalComponentNames, true));
|
|
72
72
|
var fnName = '';
|
|
73
73
|
if (ts.isCallExpression(node) && ts.isIdentifier(node.expression)) {
|
|
74
74
|
fnName = node.expression.text;
|
|
@@ -224,9 +224,9 @@ function extractMessageDescriptor(ts, node, _a, sf) {
|
|
|
224
224
|
switch (typeof overrideIdFn) {
|
|
225
225
|
case 'string':
|
|
226
226
|
if (!msg.id) {
|
|
227
|
-
msg.id = interpolate_name_1.interpolateName({ resourcePath: sf.fileName }, overrideIdFn, {
|
|
227
|
+
msg.id = (0, interpolate_name_1.interpolateName)({ resourcePath: sf.fileName }, overrideIdFn, {
|
|
228
228
|
content: msg.description
|
|
229
|
-
? msg.defaultMessage
|
|
229
|
+
? "".concat(msg.defaultMessage, "#").concat(msg.description)
|
|
230
230
|
: msg.defaultMessage,
|
|
231
231
|
});
|
|
232
232
|
}
|
|
@@ -237,7 +237,7 @@ function extractMessageDescriptor(ts, node, _a, sf) {
|
|
|
237
237
|
}
|
|
238
238
|
}
|
|
239
239
|
if (extractSourceLocation) {
|
|
240
|
-
return tslib_1.__assign(tslib_1.__assign({}, msg), { file: sf.fileName, start: node.pos, end: node.end });
|
|
240
|
+
return (0, tslib_1.__assign)((0, tslib_1.__assign)({}, msg), { file: sf.fileName, start: node.pos, end: node.end });
|
|
241
241
|
}
|
|
242
242
|
return msg;
|
|
243
243
|
}
|
|
@@ -247,10 +247,10 @@ function extractMessageDescriptor(ts, node, _a, sf) {
|
|
|
247
247
|
* @param sf
|
|
248
248
|
*/
|
|
249
249
|
function isMemberMethodFormatMessageCall(ts, node, additionalFunctionNames) {
|
|
250
|
-
var fnNames = new Set(tslib_1.__spreadArray([
|
|
250
|
+
var fnNames = new Set((0, tslib_1.__spreadArray)([
|
|
251
251
|
'formatMessage',
|
|
252
252
|
'$formatMessage'
|
|
253
|
-
], additionalFunctionNames));
|
|
253
|
+
], additionalFunctionNames, true));
|
|
254
254
|
var method = node.expression;
|
|
255
255
|
// Handle foo.formatMessage()
|
|
256
256
|
if (ts.isPropertyAccessExpression(method)) {
|
|
@@ -283,15 +283,15 @@ function extractMessageFromJsxComponent(ts, factory, node, opts, sf) {
|
|
|
283
283
|
return factory.updateJsxSelfClosingElement(node, node.tagName, node.typeArguments, factory.createJsxAttributes(newProps));
|
|
284
284
|
}
|
|
285
285
|
function setAttributesInObject(ts, factory, node, msg, ast) {
|
|
286
|
-
var newProps = tslib_1.__spreadArray([
|
|
286
|
+
var newProps = (0, tslib_1.__spreadArray)([
|
|
287
287
|
factory.createPropertyAssignment('id', factory.createStringLiteral(msg.id))
|
|
288
288
|
], (msg.defaultMessage
|
|
289
289
|
? [
|
|
290
290
|
factory.createPropertyAssignment('defaultMessage', ast
|
|
291
|
-
? messageASTToTSNode(factory, icu_messageformat_parser_1.parse(msg.defaultMessage))
|
|
291
|
+
? messageASTToTSNode(factory, (0, icu_messageformat_parser_1.parse)(msg.defaultMessage))
|
|
292
292
|
: factory.createStringLiteral(msg.defaultMessage)),
|
|
293
293
|
]
|
|
294
|
-
: []));
|
|
294
|
+
: []), true);
|
|
295
295
|
for (var _i = 0, _a = node.properties; _i < _a.length; _i++) {
|
|
296
296
|
var prop = _a[_i];
|
|
297
297
|
if (ts.isPropertyAssignment(prop) &&
|
|
@@ -306,15 +306,15 @@ function setAttributesInObject(ts, factory, node, msg, ast) {
|
|
|
306
306
|
return factory.createObjectLiteralExpression(factory.createNodeArray(newProps));
|
|
307
307
|
}
|
|
308
308
|
function generateNewProperties(ts, factory, node, msg, ast) {
|
|
309
|
-
var newProps = tslib_1.__spreadArray([
|
|
309
|
+
var newProps = (0, tslib_1.__spreadArray)([
|
|
310
310
|
factory.createJsxAttribute(factory.createIdentifier('id'), factory.createStringLiteral(msg.id))
|
|
311
311
|
], (msg.defaultMessage
|
|
312
312
|
? [
|
|
313
313
|
factory.createJsxAttribute(factory.createIdentifier('defaultMessage'), ast
|
|
314
|
-
? factory.createJsxExpression(undefined, messageASTToTSNode(factory, icu_messageformat_parser_1.parse(msg.defaultMessage)))
|
|
314
|
+
? factory.createJsxExpression(undefined, messageASTToTSNode(factory, (0, icu_messageformat_parser_1.parse)(msg.defaultMessage)))
|
|
315
315
|
: factory.createStringLiteral(msg.defaultMessage)),
|
|
316
316
|
]
|
|
317
|
-
: []));
|
|
317
|
+
: []), true);
|
|
318
318
|
for (var _i = 0, _a = node.properties; _i < _a.length; _i++) {
|
|
319
319
|
var prop = _a[_i];
|
|
320
320
|
if (ts.isJsxAttribute(prop) &&
|
|
@@ -354,7 +354,7 @@ function extractMessagesFromCallExpression(ts, factory, node, opts, sf) {
|
|
|
354
354
|
if (!msgs_1.length) {
|
|
355
355
|
return node;
|
|
356
356
|
}
|
|
357
|
-
console_utils_1.debug('Multiple messages extracted from "%s": %s', sf.fileName, msgs_1);
|
|
357
|
+
(0, console_utils_1.debug)('Multiple messages extracted from "%s": %s', sf.fileName, msgs_1);
|
|
358
358
|
if (typeof onMsgExtracted === 'function') {
|
|
359
359
|
onMsgExtracted(sf.fileName, msgs_1);
|
|
360
360
|
}
|
|
@@ -371,7 +371,7 @@ function extractMessagesFromCallExpression(ts, factory, node, opts, sf) {
|
|
|
371
371
|
}, opts.ast));
|
|
372
372
|
}));
|
|
373
373
|
var clonedDescriptorsObj = factory.createObjectLiteralExpression(clonedProperties);
|
|
374
|
-
return factory.updateCallExpression(node, node.expression, node.typeArguments, tslib_1.__spreadArray([clonedDescriptorsObj], restArgs));
|
|
374
|
+
return factory.updateCallExpression(node, node.expression, node.typeArguments, (0, tslib_1.__spreadArray)([clonedDescriptorsObj], restArgs, true));
|
|
375
375
|
}
|
|
376
376
|
}
|
|
377
377
|
else if (isSingularMessageDecl(ts, node, opts.additionalComponentNames || []) ||
|
|
@@ -382,18 +382,18 @@ function extractMessagesFromCallExpression(ts, factory, node, opts, sf) {
|
|
|
382
382
|
if (!msg) {
|
|
383
383
|
return node;
|
|
384
384
|
}
|
|
385
|
-
console_utils_1.debug('Message extracted from "%s": %s', sf.fileName, msg);
|
|
385
|
+
(0, console_utils_1.debug)('Message extracted from "%s": %s', sf.fileName, msg);
|
|
386
386
|
if (typeof onMsgExtracted === 'function') {
|
|
387
387
|
onMsgExtracted(sf.fileName, [msg]);
|
|
388
388
|
}
|
|
389
|
-
return factory.updateCallExpression(node, node.expression, node.typeArguments, tslib_1.__spreadArray([
|
|
389
|
+
return factory.updateCallExpression(node, node.expression, node.typeArguments, (0, tslib_1.__spreadArray)([
|
|
390
390
|
setAttributesInObject(ts, factory, descriptorsObj, {
|
|
391
391
|
defaultMessage: opts.removeDefaultMessage
|
|
392
392
|
? undefined
|
|
393
393
|
: msg.defaultMessage,
|
|
394
394
|
id: msg.id,
|
|
395
395
|
}, opts.ast)
|
|
396
|
-
], restArgs));
|
|
396
|
+
], restArgs, true));
|
|
397
397
|
}
|
|
398
398
|
}
|
|
399
399
|
return node;
|
|
@@ -411,13 +411,13 @@ function getVisitor(ts, ctx, sf, opts) {
|
|
|
411
411
|
return visitor;
|
|
412
412
|
}
|
|
413
413
|
function transformWithTs(ts, opts) {
|
|
414
|
-
opts = tslib_1.__assign(tslib_1.__assign({}, DEFAULT_OPTS), opts);
|
|
415
|
-
console_utils_1.debug('Transforming options', opts);
|
|
414
|
+
opts = (0, tslib_1.__assign)((0, tslib_1.__assign)({}, DEFAULT_OPTS), opts);
|
|
415
|
+
(0, console_utils_1.debug)('Transforming options', opts);
|
|
416
416
|
var transformFn = function (ctx) {
|
|
417
417
|
return function (sf) {
|
|
418
418
|
var pragmaResult = PRAGMA_REGEX.exec(sf.text);
|
|
419
419
|
if (pragmaResult) {
|
|
420
|
-
console_utils_1.debug('Pragma found', pragmaResult);
|
|
420
|
+
(0, console_utils_1.debug)('Pragma found', pragmaResult);
|
|
421
421
|
var pragma = pragmaResult[1], kvString = pragmaResult[2];
|
|
422
422
|
if (pragma === opts.pragma) {
|
|
423
423
|
var kvs = kvString.split(' ');
|
|
@@ -427,7 +427,7 @@ function transformWithTs(ts, opts) {
|
|
|
427
427
|
var _a = kv.split(':'), k = _a[0], v = _a[1];
|
|
428
428
|
result[k] = v;
|
|
429
429
|
}
|
|
430
|
-
console_utils_1.debug('Pragma extracted', result);
|
|
430
|
+
(0, console_utils_1.debug)('Pragma extracted', result);
|
|
431
431
|
if (typeof opts.onMetaExtracted === 'function') {
|
|
432
432
|
opts.onMetaExtracted(sf.fileName, result);
|
|
433
433
|
}
|
package/ts-jest-integration.js
CHANGED
|
@@ -5,6 +5,6 @@ var _1 = require(".");
|
|
|
5
5
|
exports.name = '@formatjs/ts-transformer';
|
|
6
6
|
exports.version = '2.10.1';
|
|
7
7
|
function factory(compilerInstance, opts) {
|
|
8
|
-
return _1.transformWithTs(compilerInstance.configSet.compilerModule, opts);
|
|
8
|
+
return (0, _1.transformWithTs)(compilerInstance.configSet.compilerModule, opts);
|
|
9
9
|
}
|
|
10
10
|
exports.factory = factory;
|