ts-transform-react-intl
Version:
Extracts string messages for translation from modules that use React Intl.
59 lines (51 loc) • 1.63 kB
text/typescript
import * as ts from "typescript";
import { sync as globSync } from "glob";
import { transform as intlTransformer, aggregate } from "./src";
declare module "fs-extra" {
export function outputJsonSync(file: string, data: any, opts?: {}): void;
}
const CJS_CONFIG: ts.CompilerOptions = {
experimentalDecorators: true,
jsx: ts.JsxEmit.React,
module: ts.ModuleKind.CommonJS,
moduleResolution: ts.ModuleResolutionKind.NodeJs,
noEmitOnError: false,
noUnusedLocals: true,
noUnusedParameters: true,
stripInternal: true,
declaration: true,
baseUrl: __dirname,
target: ts.ScriptTarget.ES2015
};
export default function compile(
input: string,
options: ts.CompilerOptions = CJS_CONFIG
) {
const files = globSync(input);
const compilerHost = ts.createCompilerHost(options);
const program = ts.createProgram(files, options, compilerHost);
const msgs = {};
let emitResult = program.emit(undefined, undefined, undefined, undefined, {
before: [
intlTransformer({
macroModuleSpecifier: "../../",
interpolateName: "[hash:base64:10]",
onMsgExtracted: aggregate(msgs),
baseUrl: __dirname
})
]
});
let allDiagnostics = ts
.getPreEmitDiagnostics(program)
.concat(emitResult.diagnostics);
allDiagnostics.forEach(diagnostic => {
let { line, character } = diagnostic.file.getLineAndCharacterOfPosition(
diagnostic.start
);
let message = ts.flattenDiagnosticMessageText(diagnostic.messageText, "\n");
console.log(
`${diagnostic.file.fileName} (${line + 1},${character + 1}): ${message}`
);
});
return msgs;
}