// React Native WebView cannot load external JS files, however it can load // arbitraty 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'); const cwd = process.cwd(); const outputDir = cwd + '/lib/rnInjectedJs'; const rnDir = __dirname + '/../ReactNativeClient'; async function copyJs(name, filePath) { const js = await fs.readFile(filePath, 'utf-8'); const json = 'module.exports = ' + JSON.stringify(js) + ';'; const outputPath = outputDir + '/' + name + '.js'; await fs.writeFile(outputPath, json); } async function main(argv) { await fs.mkdirp(outputDir); await copyJs('webviewLib', rnDir + '/lib/renderers/webviewLib.js'); } main(process.argv).catch((error) => { console.error(error); process.exit(1); });