2021-07-13 19:13:13 +01:00
|
|
|
// React Native WebView cannot load external JS files, however it can load
|
|
|
|
// arbitrary JS via the injectedJavaScript property. So we use this to load external
|
|
|
|
// files: First here we convert the JS file to a plain string, and that string
|
|
|
|
// is then loaded by eg. the Mermaid plugin, and finally injected in the WebView.
|
|
|
|
|
|
|
|
const fs = require('fs-extra');
|
2021-07-16 14:30:12 +01:00
|
|
|
const path = require('path');
|
2021-07-16 15:50:33 +01:00
|
|
|
const execa = require('execa');
|
2021-07-16 14:30:12 +01:00
|
|
|
|
|
|
|
const rootDir = path.dirname(path.dirname(path.dirname(__dirname)));
|
2021-07-13 19:13:13 +01:00
|
|
|
const mobileDir = `${rootDir}/packages/app-mobile`;
|
|
|
|
const outputDir = `${mobileDir}/lib/rnInjectedJs`;
|
|
|
|
const codeMirrorBundleFile = `${mobileDir}/components/NoteEditor/CodeMirror.bundle.min.js`;
|
|
|
|
|
|
|
|
async function copyJs(name, filePath) {
|
|
|
|
const outputPath = `${outputDir}/${name}.js`;
|
2021-07-16 14:30:12 +01:00
|
|
|
console.info(`Creating: ${outputPath}`);
|
2021-07-16 15:50:33 +01:00
|
|
|
const js = await fs.readFile(filePath, 'utf-8');
|
|
|
|
const json = `module.exports = ${JSON.stringify(js)};`;
|
2021-07-13 19:13:13 +01:00
|
|
|
await fs.writeFile(outputPath, json);
|
|
|
|
}
|
|
|
|
|
|
|
|
async function buildCodeMirrorBundle() {
|
2021-07-16 15:50:33 +01:00
|
|
|
console.info('Building CodeMirror bundle...');
|
|
|
|
|
2021-07-13 19:13:13 +01:00
|
|
|
const sourceFile = `${mobileDir}/components/NoteEditor/CodeMirror.ts`;
|
|
|
|
const fullBundleFile = `${mobileDir}/components/NoteEditor/CodeMirror.bundle.js`;
|
2021-07-16 15:50:33 +01:00
|
|
|
|
|
|
|
await execa('./node_modules/rollup/dist/bin/rollup', [
|
|
|
|
sourceFile,
|
|
|
|
'--name', 'codeMirrorBundle',
|
|
|
|
'-f', 'iife',
|
|
|
|
'-o', fullBundleFile,
|
|
|
|
'-p', '@rollup/plugin-node-resolve',
|
|
|
|
'-p', '@rollup/plugin-typescript',
|
|
|
|
]);
|
|
|
|
|
|
|
|
await execa('./node_modules/uglify-js/bin/uglifyjs', [
|
|
|
|
'--compress',
|
|
|
|
'-o', codeMirrorBundleFile,
|
|
|
|
fullBundleFile,
|
|
|
|
]);
|
2021-07-13 19:13:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
async function main() {
|
|
|
|
await fs.mkdirp(outputDir);
|
|
|
|
await buildCodeMirrorBundle();
|
|
|
|
await copyJs('webviewLib', `${mobileDir}/node_modules/@joplin/lib/renderers/webviewLib.js`);
|
|
|
|
await copyJs('CodeMirror.bundle', `${mobileDir}/components/NoteEditor/CodeMirror.bundle.min.js`);
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = main;
|