let { TsConfigPathsPlugin } = require('awesome-typescript-loader'); let LiveReloadPlugin = require('webpack-livereload-plugin'); let path = require('path'); const packageData = require("../../package.json"); let create = (entries, tsConfig, outDir, filename) => { return { entry: entries, mode: 'development', devtool: 'source-map', optimization: { removeAvailableModules: false, removeEmptyChunks: false, splitChunks: false, }, resolve: { symlinks: false, extensions: ['.ts', '.js'], plugins: [ // We need to use the awesome typescript loader config paths since the one for ts-loader doesn't resolve aliases correctly new TsConfigPathsPlugin({ baseUrl: '.', compiler: 'typescript', configFileName: tsConfig }) ] }, module: { rules: [ // { // test: /\.js$/, // use: [ // 'source-map-loader' // ], // enforce: 'pre' // }, { test: /\.ts$/, use: [ { loader: 'string-replace-loader', options: { test: /EditorManager.ts/, multiple: [ { search: '@@majorVersion@@', replace: packageData.version.split('.')[0], }, { search: '@@minorVersion@@', replace: packageData.version.split('.').slice(1).join('.'), }, { search: '@@releaseDate@@', replace: packageData.date, } ] } }, { loader: 'ts-loader', options: { transpileOnly: true, configFile: tsConfig, experimentalWatchApi: true } } // { // loader: 'awesome-typescript-loader', // options: { // transpileOnly: true, // configFileName: tsConfig // } // } ] } ] }, plugins: [ new LiveReloadPlugin() ], output: { filename: typeof entries === 'string' ? filename : "[name]/" + filename, path: path.resolve(outDir), pathinfo: false } }; }; let buildDemoEntries = (pluginNames, type, demo) => pluginNames.reduce( (acc, name) => { acc[name] = `src/${type}/${name}/demo/ts/demo/${demo}`; return acc; }, {} ) let buildEntries = (pluginNames, type, entry) => pluginNames.reduce( (acc, name) => { acc[name] = `src/${type}/${name}/main/ts/${entry}`; return acc; }, {} ) let createPlugin = (name) => { return create(`src/plugins/${name}/demo/ts/demo/Demo.ts`, 'tsconfig.plugin.json', `scratch/demos/plugins/${name}/`, 'demo.js'); }; let createTheme = (name) => { return create(`src/themes/${name}/demo/ts/demo/Demos.ts`, 'tsconfig.theme.json', `scratch/demos/themes/${name}`, 'demo.js'); }; let allPluginDemos = (plugins) => { return create(buildDemoEntries(plugins, 'plugins', 'Demo.ts'), 'tsconfig.plugin.json', 'scratch/demos/plugins', 'demo.js') } let allThemeDemos = (themes) => { return create(buildDemoEntries(themes, 'themes', 'Demos.ts'), 'tsconfig.theme.json', 'scratch/demos/themes', 'demo.js') } let all = (plugins, themes) => { return [ allPluginDemos(plugins), allThemeDemos(themes), create(`src/core/demo/ts/demo/Demos.ts`, 'tsconfig.json', 'scratch/demos/core/', 'demo.js'), create('src/core/main/ts/api/Main.ts', 'tsconfig.json', 'js/tinymce/', 'tinymce.js'), create(buildEntries(plugins, 'plugins', 'Plugin.ts'), 'tsconfig.plugin.json', 'js/tinymce/plugins', 'plugin.js'), create(buildEntries(themes, 'themes', 'Theme.ts'), 'tsconfig.theme.json', 'js/tinymce/themes', 'theme.js') ]; } let generateDemoIndex = (grunt, app, plugins, themes) => { let demoList = grunt.file.expand(['src/**/demo/html/*.html']) let sortedDemos = demoList.reduce((acc, link) => { const type = link.split('/')[1]; if (!acc[type]) { acc[type] = []; } acc[type].push(link) return acc; }, {}) let lists = Object.keys(sortedDemos).map( type => `