From fdc91d0733b0ae68bfabe02fc281dfe0320ab2a4 Mon Sep 17 00:00:00 2001 From: Nolan Lawson Date: Sat, 23 Sep 2017 17:06:29 -0700 Subject: [PATCH] Build as ES module as well as CommonJS --- .babelrc | 10 ++++++++-- .gitignore | 1 + package.json | 9 ++++++--- scripts/build-data.js | 3 +++ src/polyfills/createClass.js | 4 ++-- src/polyfills/extends.js | 2 +- src/polyfills/inherits.js | 2 +- src/polyfills/objectGetPrototypeOf.js | 2 +- src/polyfills/possibleConstructorReturn.js | 2 +- src/polyfills/stringFromCodePoint.js | 2 +- src/utils/build-search.js | 2 +- 11 files changed, 26 insertions(+), 13 deletions(-) diff --git a/.babelrc b/.babelrc index 325fe32..d240a0b 100644 --- a/.babelrc +++ b/.babelrc @@ -12,7 +12,6 @@ "transform-es2015-for-of", "transform-es2015-function-name", "transform-es2015-literals", - "transform-es2015-modules-commonjs", "transform-es2015-object-super", "transform-es2015-parameters", "transform-es2015-shorthand-properties", @@ -40,5 +39,12 @@ } } ] - ] + ], + "env": { + "cjs": { + "plugins": [ + "transform-es2015-modules-commonjs" + ] + } + } } diff --git a/.gitignore b/.gitignore index a74e2b8..efd3173 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ node_modules/ dist/ +dist-es/ bundle.js diff --git a/package.json b/package.json index f0b0248..a95a61c 100644 --- a/package.json +++ b/package.json @@ -3,6 +3,7 @@ "version": "2.0.1", "description": "Customizable Slack-like emoji picker for React", "main": "dist/index.js", + "module": "dist-es/index.js", "repository": { "type": "git", "url": "git@github.com:missive/emoji-mart.git" @@ -61,11 +62,13 @@ "webpack": "^3.6.0" }, "scripts": { - "clean": "rm -rf dist/", + "clean": "rm -rf dist/ dist-es/", "build:data": "node scripts/build-data", - "build:dist": "npm run clean && babel src --out-dir dist --copy-files --ignore webpack.config.js", + "build:dist": "npm run clean && npm run build:cjs && npm run build:es", + "build:cjs": "BABEL_ENV=cjs babel src --out-dir dist --copy-files --ignore webpack.config.js", + "build:es": "babel src --out-dir dist-es --copy-files --ignore webpack.config.js", "build": "npm run build:dist && npm run build:data", - "watch": "babel src --watch --out-dir dist --copy-files --ignore webpack.config.js", + "watch": "BABEL_ENV=cjs babel src --watch --out-dir dist --copy-files --ignore webpack.config.js", "start": "npm run watch", "stats": "webpack --config ./src/webpack.config.js --json > stats.json", "react:clean": "rimraf node_modules/{react,react-dom,react-addons-test-utils}", diff --git a/scripts/build-data.js b/scripts/build-data.js index dd9da0a..a692b7c 100644 --- a/scripts/build-data.js +++ b/scripts/build-data.js @@ -143,4 +143,7 @@ flags.emojis = flags.emojis.filter((flag) => { const stringified = JSON.stringify(data).replace(/\"([A-Za-z_]+)\":/g, '$1:') fs.writeFile('dist/data/data.js', `module.exports = ${stringified}`, (err) => { if (err) throw err + fs.writeFile('dist-es/data/data.js', `export default ${stringified}`, (err) => { + if (err) throw err + }) }) diff --git a/src/polyfills/createClass.js b/src/polyfills/createClass.js index 93f9078..75fd54f 100644 --- a/src/polyfills/createClass.js +++ b/src/polyfills/createClass.js @@ -1,6 +1,6 @@ const _Object = Object -module.exports = function createClass() { +export default (function createClass() { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; @@ -16,4 +16,4 @@ module.exports = function createClass() { if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; -}(); +}()); diff --git a/src/polyfills/extends.js b/src/polyfills/extends.js index 9acd0a5..33fe6e6 100644 --- a/src/polyfills/extends.js +++ b/src/polyfills/extends.js @@ -1,6 +1,6 @@ const _Object = Object -module.exports = _Object.assign || function (target) { +export default _Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; diff --git a/src/polyfills/inherits.js b/src/polyfills/inherits.js index 941b134..4cef088 100644 --- a/src/polyfills/inherits.js +++ b/src/polyfills/inherits.js @@ -1,6 +1,6 @@ const _Object = Object -module.exports = function inherits(subClass, superClass) { +export default function inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } diff --git a/src/polyfills/objectGetPrototypeOf.js b/src/polyfills/objectGetPrototypeOf.js index 29e67dd..89d5375 100644 --- a/src/polyfills/objectGetPrototypeOf.js +++ b/src/polyfills/objectGetPrototypeOf.js @@ -1,6 +1,6 @@ const _Object = Object -module.exports = _Object.getPrototypeOf || function (O) { +export default _Object.getPrototypeOf || function (O) { O = Object(O) if (typeof O.constructor === 'function' && O instanceof O.constructor) { diff --git a/src/polyfills/possibleConstructorReturn.js b/src/polyfills/possibleConstructorReturn.js index 24c3a94..33b768a 100644 --- a/src/polyfills/possibleConstructorReturn.js +++ b/src/polyfills/possibleConstructorReturn.js @@ -1,4 +1,4 @@ -module.exports = function possibleConstructorReturn(self, call) { +export default function possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } diff --git a/src/polyfills/stringFromCodePoint.js b/src/polyfills/stringFromCodePoint.js index 8a3215f..a53a5e3 100644 --- a/src/polyfills/stringFromCodePoint.js +++ b/src/polyfills/stringFromCodePoint.js @@ -1,6 +1,6 @@ const _String = String -module.exports = _String.fromCodePoint || function stringFromCodePoint() { +export default _String.fromCodePoint || function stringFromCodePoint() { var MAX_SIZE = 0x4000; var codeUnits = []; var highSurrogate; diff --git a/src/utils/build-search.js b/src/utils/build-search.js index a434f50..153f952 100644 --- a/src/utils/build-search.js +++ b/src/utils/build-search.js @@ -1,4 +1,4 @@ -module.exports = data => { +export default data => { const search = [] var addToSearch = (strings, split) => {