Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[core] Migrate @mui/x-license-pro to the new bundling strategy #3738

Merged
merged 36 commits into from
Feb 14, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
0d0fabd
[core] Prepare infra for pickers migration
flaviendelangle Jan 24, 2022
7789edf
Work
flaviendelangle Jan 24, 2022
a6ffec7
Merge
flaviendelangle Jan 25, 2022
ee608a3
Merge branch 'master' into infra-pickers
flaviendelangle Jan 25, 2022
f92743f
[core] Migrate @mui/x-license-pro to the new bundling strategy
flaviendelangle Jan 25, 2022
a68383b
Work
flaviendelangle Jan 25, 2022
d5eaabc
Merge
flaviendelangle Feb 1, 2022
b99abfc
Work
flaviendelangle Feb 1, 2022
262c77b
Fix
flaviendelangle Feb 1, 2022
0e38aa4
Fix
flaviendelangle Feb 1, 2022
3be34b8
Fix
flaviendelangle Feb 1, 2022
6bc170b
Fix
flaviendelangle Feb 1, 2022
74eb662
Empty
flaviendelangle Feb 1, 2022
7ea7b7a
Merge branch 'master' into x-license-pro-bundling
flaviendelangle Feb 3, 2022
d4b33b4
work
flaviendelangle Feb 3, 2022
a21c484
Work
flaviendelangle Feb 3, 2022
0ad6c9f
Work
flaviendelangle Feb 3, 2022
be7c0da
Work
flaviendelangle Feb 3, 2022
dd5e2ef
Work
flaviendelangle Feb 3, 2022
6c96aff
Work
flaviendelangle Feb 3, 2022
cfd4c8e
Work
flaviendelangle Feb 3, 2022
30823d0
Work
flaviendelangle Feb 3, 2022
c90ad6a
Work
flaviendelangle Feb 3, 2022
6b8abbb
Work
flaviendelangle Feb 3, 2022
2b4a0e0
Work
flaviendelangle Feb 3, 2022
f43fe3c
Work
flaviendelangle Feb 3, 2022
fa69aee
Fix
flaviendelangle Feb 3, 2022
a204b9c
Work
flaviendelangle Feb 3, 2022
e08a964
Work
flaviendelangle Feb 3, 2022
a6a2a70
Work
flaviendelangle Feb 3, 2022
d8c5d6c
Work
flaviendelangle Feb 3, 2022
839aa59
Work
flaviendelangle Feb 3, 2022
a054c1b
Work
flaviendelangle Feb 7, 2022
eeeeedc
Merge branch 'master' into x-license-pro-bundling
flaviendelangle Feb 8, 2022
c7417c0
Merge branch 'master' into x-license-pro-bundling
flaviendelangle Feb 11, 2022
bacb7d8
Fix
flaviendelangle Feb 11, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
169 changes: 118 additions & 51 deletions babel.config.js
Original file line number Diff line number Diff line change
@@ -1,24 +1,5 @@
const path = require('path');
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I synced this file with the core one, minus some things (we don't have there error management for instance).
I will do some tests for the packages still on the old bundling. But I would advise against releasing a state where some package use the core bundling strategy and others don't.


let defaultPresets;

// We release a ES version of MUI.
// It's something that matches the latest official supported features of JavaScript.
// Nothing more (stage-1, etc), nothing less (require, etc).
if (process.env.BABEL_ENV === 'es') {
defaultPresets = [];
} else {
defaultPresets = [
[
'@babel/preset-env',
{
bugfixes: true,
modules: ['esm', 'production-umd'].includes(process.env.BABEL_ENV) ? false : 'commonjs',
},
],
];
}

function resolveAliasPath(relativeToBabelConf) {
const resolvedPath = path.relative(process.cwd(), path.resolve(__dirname, relativeToBabelConf));
return `./${resolvedPath.replace('\\', '/')}`;
Expand All @@ -31,53 +12,139 @@ const defaultAlias = {
'@mui/x-license-pro': resolveAliasPath('./packages/x-license-pro/src'),
'typescript-to-proptypes': '@mui/monorepo/packages/typescript-to-proptypes/src',
docs: resolveAliasPath('./node_modules/@mui/monorepo/docs'),
test: resolveAliasPath('./test'),
packages: resolveAliasPath('./packages'),
};

module.exports = {
presets: defaultPresets.concat(['@babel/preset-react', '@babel/preset-typescript']),
plugins: [
const productionPlugins = [
['babel-plugin-react-remove-properties', { properties: ['data-mui-test'] }],
];

module.exports = function getBabelConfig(api) {
const useESModules = api.env(['legacy', 'modern', 'stable', 'rollup']);

const presets = [
[
'@babel/preset-env',
{
bugfixes: true,
browserslistEnv: process.env.BABEL_ENV || process.env.NODE_ENV,
debug: process.env.MUI_BUILD_VERBOSE === 'true',
modules: useESModules ? false : 'commonjs',
shippedProposals: api.env('modern'),
},
],
[
'@babel/preset-react',
{
runtime: 'automatic',
},
],
'@babel/preset-typescript',
];

const plugins = [
'babel-plugin-optimize-clsx',
// Need the following 3 proposals for all targets in .browserslistrc.
// With our usage the transpiled loose mode is equivalent to spec mode.
['@babel/plugin-proposal-class-properties', { loose: true }],
['@babel/plugin-proposal-private-methods', { loose: true }],
['@babel/plugin-proposal-private-property-in-object', { loose: true }],
['@babel/plugin-proposal-object-rest-spread', { loose: true }],
// any package needs to declare 7.4.4 as a runtime dependency. default is ^7.0.0
['@babel/plugin-transform-runtime', { version: '^7.4.4' }],
// for IE 11 support
'@babel/plugin-transform-object-assign',
[
'@babel/plugin-transform-runtime',
{
useESModules,
// any package needs to declare 7.4.4 as a runtime dependency. default is ^7.0.0
version: '^7.4.4',
},
],
[
'babel-plugin-transform-react-remove-prop-types',
{
mode: 'unsafe-wrap',
},
],
];

if (process.env.NODE_ENV === 'production') {
plugins.push(...productionPlugins);
}
if (process.env.NODE_ENV === 'test') {
plugins.push([
'babel-plugin-module-resolver',
{
root: ['./'],
extensions: ['.js', '.ts', '.tsx'],
alias: defaultAlias,
root: ['./'],
},
],
],
ignore: [
// Fix a Windows issue.
/@babel[\\|/]runtime/,
// Fix const foo = /{{(.+?)}}/gs; crashing.
/prettier/,
],
env: {
coverage: {
plugins: ['babel-plugin-istanbul'],
},
test: {
sourceMaps: 'both',
]);
}

return {
assumptions: {
noDocumentAll: true,
},
benchmark: {
plugins: [
[
'babel-plugin-module-resolver',
{
alias: defaultAlias,
},
presets,
plugins,
ignore: [
// Fix a Windows issue.
/@babel[\\|/]runtime/,
// Fix const foo = /{{(.+?)}}/gs; crashing.
/prettier/,
],
env: {
coverage: {
plugins: [
'babel-plugin-istanbul',
[
'babel-plugin-module-resolver',
{
root: ['./'],
alias: defaultAlias,
},
],
],
},
development: {
plugins: [
[
'babel-plugin-module-resolver',
{
alias: defaultAlias,
root: ['./'],
},
],
],
},
legacy: {
plugins: [
// IE11 support
'@babel/plugin-transform-object-assign',
],
},
test: {
sourceMaps: 'both',
plugins: [
[
'babel-plugin-module-resolver',
{
root: ['./'],
alias: defaultAlias,
},
],
],
],
},
benchmark: {
plugins: [
...productionPlugins,
[
'babel-plugin-module-resolver',
{
alias: defaultAlias,
},
],
],
},
},
},
};
};
18 changes: 14 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -57,19 +57,24 @@
"build:codesandbox": "yarn release:build",
"release:changelog": "node scripts/releaseChangelog",
"release:version": "lerna version --exact --no-changelog --no-push --no-git-tag-version",
"release:build": "cd packages/x-license-pro && yarn build && cd ../grid/x-data-grid-pro && yarn build && cd ../x-data-grid && yarn build && cd ../x-data-grid-generator && yarn build",
"release:build": "yarn release:build:next && cd packages/grid/x-data-grid-pro && yarn build && cd ../x-data-grid && yarn build && cd ../x-data-grid-generator && yarn build",
"release:build:next": "lerna run --parallel --scope \"@mui/x-license-pro\" build",
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm following mui/material-ui#30201, mui/material-ui#30200 because we will probably have the same issue.
But for now it's not a problem since I build the only package with the core bundling strategy before the others.

"release:publish": "lerna publish from-package --dist-tag latest --contents build",
"release:publish:dry-run": "lerna publish from-package --dist-tag latest --contents build --registry=\"http://localhost:4873/\""
},
"devDependencies": {
"@babel/cli": "^7.16.0",
"@babel/cli": "^7.16.8",
"@babel/core": "^7.16.12",
"@babel/node": "^7.16.8",
"@babel/plugin-proposal-class-properties": "^7.16.7",
"@babel/plugin-proposal-object-rest-spread": "^7.16.7",
"@babel/plugin-transform-object-assign": "^7.16.7",
"@babel/plugin-transform-react-constant-elements": "^7.16.7",
"@babel/plugin-transform-runtime": "^7.16.10",
"@babel/preset-env": "^7.16.11",
"@babel/preset-react": "^7.16.7",
"@babel/preset-typescript": "^7.16.7",
"@babel/register": "^7.16.9",
"@babel/runtime": "^7.16.7",
"@babel/traverse": "^7.16.10",
"@babel/types": "^7.16.8",
"@emotion/cache": "^11.7.1",
Expand Down Expand Up @@ -101,10 +106,15 @@
"@typescript-eslint/eslint-plugin": "^5.11.0",
"@typescript-eslint/parser": "^5.11.0",
"argos-cli": "^0.3.3",
"babel-loader": "^8.2.3",
"babel-plugin-istanbul": "^6.1.1",
"babel-plugin-module-resolver": "^4.1.0",
"babel-plugin-optimize-clsx": "^2.6.2",
"babel-plugin-transform-react-remove-prop-types": "^0.4.24",
"babel-plugin-react-remove-properties": "^0.3.0",
"babel-plugin-search-and-replace": "^1.1.0",
"babel-plugin-tester": "^10.1.0",
"babel-plugin-transform-rename-import": "^2.3.0",
"babel-plugin-transform-react-remove-prop-types": "^0.4.24",
"chai": "^4.3.6",
"chai-dom": "^1.11.0",
"compression-webpack-plugin": "^9.2.0",
Expand Down
17 changes: 12 additions & 5 deletions packages/grid/rollup.x-data-grid-pro.config.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import { generateReleaseInfo } from '@mui/x-license-pro';
import replace from '@rollup/plugin-replace';
import babel from '@rollup/plugin-babel';
import typescript from 'rollup-plugin-typescript2';
import cleaner from 'rollup-plugin-cleaner';
Expand Down Expand Up @@ -32,24 +31,32 @@ export default [
return new RegExp(`(${packageName}|${packageName}\\/.*)`);
}),
plugins: [
replace({
__RELEASE_INFO__: generateReleaseInfo(),
}),
production &&
cleaner({
targets: ['./x-data-grid-pro/build/'],
}),
typescript({ tsconfig: 'tsconfig.build.json' }),
babel({
babelHelpers: 'bundled',
extensions: ['.tsx'],
extensions: ['.tsx', '.ts'],
plugins: [
[
'transform-react-remove-prop-types',
{
ignoreFilenames: ['DataGridPro.tsx'],
},
],
[
'search-and-replace',
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I moved this replace to babel because once we remove rollup for @mui/x-data-grid-pro we won't be able to use to current plugin.

{
rules: [
{
search: '__RELEASE_INFO__',
replace: generateReleaseInfo(),
},
],
},
],
],
}),
!production && sourceMaps(),
Expand Down
File renamed without changes.
31 changes: 19 additions & 12 deletions packages/x-license-pro/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,30 +3,37 @@
"version": "5.5.1",
"description": "MUI X License verification",
"author": "MUI Team",
"main": "build/cjs/index.js",
"main": "build/index.js",
"module": "build/esm/index.js",
"types": "build/x-license-pro.d.ts",
"scripts": {
"typescript": "tsc -p tsconfig.json",
"build": "rollup -c"
},
"repository": {
"type": "git",
"url": "https://github.com/mui/mui-x.git",
"directory": "packages/x-license-pro"
},
"types": "build/index.d.ts",
"license": "SEE LICENSE IN LICENSE.txt",
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We now need a valid license field for bundling

"bugs": {
"url": "https://github.com/mui/mui-x/issues"
},
"homepage": "https://mui.com/components/data-grid/",
"license": "See LICENSE file",
"sideEffects": false,
"publishConfig": {
"access": "public"
},
"bin": {
"licensegen": "./bin/license-gen-script.js"
},
"scripts": {
"typescript": "tsc -p tsconfig.json",
"build": "yarn build:legacy && yarn build:modern && yarn build:node && yarn build:stable && yarn build:types && yarn build:copy-files ",
"build:legacy": "node ../../scripts/build legacy",
"build:modern": "node ../../scripts/build modern",
"build:node": "node ../../scripts/build node",
"build:stable": "node ../../scripts/build stable",
"build:copy-files": "node ../../scripts/copyFiles.js",
"build:types": "node ../../scripts/buildTypes",
"prebuild": "rimraf build tsconfig.build.tsbuildinfo"
},
"repository": {
"type": "git",
"url": "https://github.com/mui/mui-x.git",
"directory": "packages/x-license-pro"
},
"dependencies": {
"@mui/utils": "^5.4.1",
"esm": "^3.2.25",
Expand Down
Loading