Browse Source

Add support for module

pull/5399/head
Artur Arseniev 2 years ago
parent
commit
6346fc2695
  1. 16
      package.json
  2. 4
      src/plugin_manager/index.ts
  3. 79
      webpack.config.js

16
package.json

@ -7,6 +7,18 @@
"homepage": "http://grapesjs.com", "homepage": "http://grapesjs.com",
"main": "dist/grapes.min.js", "main": "dist/grapes.min.js",
"types": "dist/index.d.ts", "types": "dist/index.d.ts",
"module": "dist/grapes.mjs",
"exports": {
".": {
"import": "./dist/grapes.mjs",
"require": "./dist/grapes.min.js"
},
"./*": "./*"
},
"files": [
"dist",
"locale"
],
"sideEffects": [ "sideEffects": [
"*.vue", "*.vue",
"*.css", "*.css",
@ -107,8 +119,10 @@
"lint": "eslint . --ext .ts,.js && npm run lint:ts", "lint": "eslint . --ext .ts,.js && npm run lint:ts",
"check": "npm run lint && npm run test", "check": "npm run lint && npm run test",
"lint:ts": "tsc --noEmit", "lint:ts": "tsc --noEmit",
"build": "npm run check && run-s build:* && npm run ts:check", "build": "npm run check && npm run build-all && npm run ts:check",
"build-all": "run-s build:*",
"build:js": "grapesjs-cli build --targets=\"> 1%, ie 11, safari 8, not dead\" --statsOutput=\"stats.json\" --localePath=\"src/i18n/locale\"", "build:js": "grapesjs-cli build --targets=\"> 1%, ie 11, safari 8, not dead\" --statsOutput=\"stats.json\" --localePath=\"src/i18n/locale\"",
"build:mjs": "BUILD_MODULE=true grapesjs-cli build --dts='skip' --patch=0 --targets=\"> 1%, ie 11, safari 8, not dead\"",
"build:css": "sass src/styles/scss/main.scss dist/css/grapes.min.css --no-source-map --style=compressed --load-path=node_modules", "build:css": "sass src/styles/scss/main.scss dist/css/grapes.min.css --no-source-map --style=compressed --load-path=node_modules",
"ts:build": "grapesjs-cli build --dts='only' --patch=0", "ts:build": "grapesjs-cli build --dts='only' --patch=0",
"ts:check": "tsc --noEmit --esModuleInterop dist/index.d.ts", "ts:check": "tsc --noEmit --esModuleInterop dist/index.d.ts",

4
src/plugin_manager/index.ts

@ -19,7 +19,9 @@ const getPluginById = (pluginId: string, plugins: PluginManager) => {
}; };
export const getPlugin = (plugin: string | Plugin<any>, plugins: PluginManager) => { export const getPlugin = (plugin: string | Plugin<any>, plugins: PluginManager) => {
return isString(plugin) ? getPluginById(plugin, plugins) : plugin; return isString(plugin)
? getPluginById(plugin, plugins)
: (plugin as unknown as { default: Plugin<any> })?.default || plugin;
}; };
export const logPluginWarn = (editor: Editor, plugin: string) => { export const logPluginWarn = (editor: Editor, plugin: string) => {

79
webpack.config.js

@ -1,35 +1,50 @@
const path = require('path'); const path = require('path');
const rootDir = path.resolve(__dirname); const rootDir = path.resolve(__dirname);
module.exports = ({ config, pkg, webpack }) => ({ module.exports = ({ config, pkg, webpack }) => {
...config, const { BUILD_MODULE } = process.env;
output: {
...config.output, return {
filename: 'grapes.min.js', ...config,
// This will assign all exports to the global object output: {
library: undefined, ...config.output,
}, filename: BUILD_MODULE ? 'grapes.mjs' : 'grapes.min.js',
devServer: { ...(BUILD_MODULE ? {
...config.devServer, libraryTarget: 'module',
static: [rootDir], library: { type: 'module' },
headers: { 'Access-Control-Allow-Origin': '*' }, } : {
allowedHosts: 'all', libraryExport: 'default'
}, })
resolve: { },
...config.resolve, optimization: {
modules: [ ...config.optimization,
...(config.resolve && config.resolve.modules), minimize: !BUILD_MODULE,
'src' },
], devServer: {
alias: { ...config.devServer,
...(config.resolve && config.resolve.alias), static: [rootDir],
jquery: 'utils/cash-dom', headers: { 'Access-Control-Allow-Origin': '*' },
backbone: `${rootDir}/node_modules/backbone`, allowedHosts: 'all',
underscore: `${rootDir}/node_modules/underscore`, },
} experiments: {
}, outputModule: !!BUILD_MODULE,
plugins: [ },
new webpack.DefinePlugin({ __GJS_VERSION__: `'${pkg.version}'` }), resolve: {
...config.plugins, ...config.resolve,
] modules: [
}); ...(config.resolve && config.resolve.modules),
'src'
],
alias: {
...(config.resolve && config.resolve.alias),
jquery: 'utils/cash-dom',
backbone: `${rootDir}/node_modules/backbone`,
underscore: `${rootDir}/node_modules/underscore`,
}
},
plugins: [
new webpack.DefinePlugin({ __GJS_VERSION__: `'${pkg.version}'` }),
...config.plugins,
]
}
};

Loading…
Cancel
Save