-
-
Notifications
You must be signed in to change notification settings - Fork 26.9k
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
Make error overlay to run in the context of the iframe #3142
Conversation
bbab2b8
to
63eab15
Compare
"start": "rimraf lib/ && cross-env NODE_ENV=development webpack --config webpack.config.js -w & NODE_ENV=development babel src/ -d lib/ -w", | ||
"test": "flow && cross-env NODE_ENV=test jest", | ||
"build": "rimraf lib/ && cross-env NODE_ENV=development babel src/ -d lib/ && cross-env NODE_ENV=production webpack --config webpack.config.js", | ||
"build:prod": "rimraf lib/ && cross-env NODE_ENV=production babel src/ -d lib/ && cross-env NODE_ENV=production webpack --config webpack.config.js" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why are we still compiling with Babel? We should just let webpack handle all of this if we're making the switch to a bundle imo.
Not sure if we want to support legacy use of the package via lib/
, /cc @gaearon.
edit: ah, I see -- we still import index which relies on some modules.
Wouldn't it be better to bundle this entire thing up -- the way it works currently is pretty confusing, unless we make the distinction and actually split the bundled code & unbundled into two separate directories; what do you think?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See #3142 (comment)
import { applyStyles } from './utils/dom/css'; | ||
|
||
/* eslint-disable import/no-webpack-loader-syntax */ | ||
//$FlowFixMe | ||
import iframeScript from 'raw-loader!./bundle.js'; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This hack is fine for now IMO, as long as we switch it eventually (once we iron out how to handle raw files).
|
||
module.exports = { | ||
devtool: 'cheap-module-source-map', | ||
entry: './src/iframeScript.js', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we bundle polyfills? 🤔
or we could document it and leave it up to the person importing it ...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I think we should. Polyfills on parent context don't seem to have an effect on the iframe context. We need polyfills to run in some browsers. (see #3034). I'll update.
Hello! I'm a bot that helps facilitate testing pull requests. Your pull request (commit 63eab15502b497324329bf8f2290b942d16a4f59) has been released on npm for testing purposes. npm i react-scripts-dangerous@1.0.14-63eab15.0
# or
yarn add react-scripts-dangerous@1.0.14-63eab15.0
# or
create-react-app --scripts-version=react-scripts-dangerous@1.0.14-63eab15.0 folder/ Note that the package has not been reviewed or vetted by the maintainers. Only install it at your own risk! Thanks for your contribution! |
@@ -54,6 +56,7 @@ | |||
"flow-bin": "^0.54.0", | |||
"jest": "20.0.4", | |||
"jest-fetch-mock": "1.2.1", | |||
"raw-loader": "^0.5.1", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Testing with the release by @react-scripts-dangerous caught this:
Failed to compile.
./node_modules/react-error-overlay-dangerous/lib/index.js
Module not found: Can't resolve 'raw-loader' in '/Users/joe/Desktop/folder2/node_modules/react-error-overlay-dangerous/lib'
I assume this should be a normal dependency.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I assume our e2e tests didn't test this because we don't run npm with NODE_ENV
as production
; but can we do that in our tests -- I assume linking makes this really weird?
Is it worth trying to test in our E2E; or we could make @react-scripts-dangerous also run its own smoke tests and comment on PRs? Not sure how often this will be a problem ...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good catch with @react-scripts-dangerous 😀
Maybe in e2e, so that we can find errors before creating a PR??
Can we just bundle the entire thing ahead of time? Then we don't need hacks for raw loader because we can use webpack directly. |
@gaearon @Timer I actually tried few ways to bundle entire thing using webpack and came across some issues. That's why I decided to go with this though it's confusing. First, I tried to bundle everything into one single file with a config like follows but still importing
The issue with this approach is that since we directly importing Then I tried to bundle
This gives an error as webpack can't resolve What am I missing here? |
Creating two separate bundles sounds appropriate; can't you just adjust the resolver to fallback to the Or, maybe simpler, add an alias for
and switch import/require to Sorry if I'm missing the point here. |
This might work. I'll give a try. Thanks! |
Resolving with alias doesn't work in the first run and starts to work perfectly from the second without Also, I tried to use multiple configs instead of multiple entry points but it doesn't make any difference. I have few more ideas to try out. Meanwhile, appreciate if anyone can shed some light on this. |
You may just need to run webpack twice. |
You mean using a build script with webpack API? |
I was thinking: cross-env NODE_ENV=production webpack --config webpack.config.iframe.js && cross-env NODE_ENV=production webpack --config webpack.config.whatever.js |
You could do a build script with the webpack API, too. |
Yes. I think using a build script will be clearer. I'll write one. |
Hello! I'm a bot that helps facilitate testing pull requests. Your pull request (commit a3bdee8dab32bd9e15cc51fdae051bf83afe0433) has been released on npm for testing purposes. npm i react-scripts-dangerous@1.0.14-a3bdee8.0
# or
yarn add react-scripts-dangerous@1.0.14-a3bdee8.0
# or
create-react-app --scripts-version=react-scripts-dangerous@1.0.14-a3bdee8.0 folder/ Note that the package has not been reviewed or vetted by the maintainers. Only install it at your own risk! Thanks for your contribution! |
"react": "^15 || ^16", | ||
"react-dom": "^15 || ^16", | ||
"settle-promise": "1.0.0", | ||
"source-map": "0.5.6" | ||
"source-map": "0.5.6", | ||
"webpack": "^3.6.0" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm assuming this should be a dev dependency.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh, how did I miss that 🤔
@@ -35,15 +35,20 @@ | |||
"babel-code-frame": "6.22.0", | |||
"babel-runtime": "6.26.0", | |||
"html-entities": "1.2.1", | |||
"object-assign": "^4.1.1", | |||
"promise": "^8.0.1", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's pin these versions.
Hello! I'm a bot that helps facilitate testing pull requests. Your pull request (commit 009fc0150343a394d2511ae751710fbb5d9a337b) has been released on npm for testing purposes. npm i react-scripts-dangerous@1.0.14-009fc01.0
# or
yarn add react-scripts-dangerous@1.0.14-009fc01.0
# or
create-react-app --scripts-version=react-scripts-dangerous@1.0.14-009fc01.0 folder/ Note that the package has not been reviewed or vetted by the maintainers. Only install it at your own risk! Thanks for your contribution! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM. Feel free to merge [via squash] if you think this is ready.
{ | ||
loader: 'babel-loader', | ||
options: { | ||
cacheDirectory: true, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's not cache just to be safe.
{ | ||
loader: 'babel-loader', | ||
options: { | ||
cacheDirectory: true, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ditto.
Ok. I'll merge this later today. |
009fc01
to
bec0436
Compare
Hello! I'm a bot that helps facilitate testing pull requests. Your pull request (commit bec04364e700cf336f2cf58a7e9a1d7849793aef) has been released on npm for testing purposes. npm i react-scripts-dangerous@1.0.15-bec0436.0
# or
yarn add react-scripts-dangerous@1.0.15-bec0436.0
# or
create-react-app --scripts-version=react-scripts-dangerous@1.0.15-bec0436.0 folder/ Note that the package has not been reviewed or vetted by the maintainers. Only install it at your own risk! Thanks for your contribution! |
bec0436
to
57274a4
Compare
…react-app * 'master' of https://github.com/facebookincubator/create-react-app: Make error overlay to run in the context of the iframe (facebook#3142) Fix Windows compatibility (facebook#3232) Fix package management link in README (facebook#3227) Watch for changes in `src/**/node_modules` (facebook#3230) More spec compliant HTML template (facebook#2914) Minor change to highlight dev proxy behaviour (facebook#3075) Correct manual proxy documentation (facebook#3185) Improve grammar in README (facebook#3211) Publish Fix license comments Changelog for 1.0.14 BSD+Patents -> MIT (facebook#3189) Add link to active CSS modules discussion (facebook#3163) Update webpack-dev-server to 2.8.2 (facebook#3157) Part of class fields to stage 3 (facebook#2908) Update unclear wording in webpack config docs (facebook#3160) Display pid in already running message (facebook#3131) Link local react-error-overlay package in kitchensink test
…pescript * 'master' of https://github.com/wmonk/create-react-app-typescript: (265 commits) fix typo in changelog Update README For 2.13.0 v2.13.0 Remove tslint-loader from prod build (again) Include TypeScript as devDependency in boilerplate output Documented how to define custom module formats for the TypeScript compiler so that you can import images and other files (references wmonk#172) v2.12.0 Update README For 2.12.0 Update typescript to 2.6.2 v2.11.0 Update changelog for 2.11.0 Fixed problem with tsconfig.json baseUrl and paths Update createJestConfig.js Update changelog for 2.10.0 v2.10.0 Readd transformIgnorePatterns Update react-dev-utils Update package.json dependencies Readd Missing raf Package Update JestConfig Creation Fix Fix Missing Variable Fix package.json Merge pull request wmonk#204 from StefanSchoof/patch-1 Merge pull request wmonk#201 from StefanSchoof/patch-1 Merge pull request wmonk#199 from DorianGrey/master Merge pull request wmonk#165 from johnnyreilly/master Publish Add 1.0.17 changelog (#3402) Use new WebpackDevServer option (#3401) Fix grammar in README (#3394) Add link to VS Code troubleshooting guide (#3399) Update VS Code debug configuration (#3400) Update README.md (#3392) Publish Reorder publishing instructions Changelog for 1.0.16 (#3376) Update favicon description (#3374) Changelog for 1.0.15 (#3357) Replace template literal; fixes #3367 (#3368) CLI@1.4.2 Publish Add preflight CWD check for npm (#3355) Stop using `npm link` in tests (#3345) Fix for add .gitattributes file #3080 (#3122) Mention that start_url needs to be "." for client side routing start using npm-run-all to build scss and js (#2957) Updating the Service Worker opt-out documentation (#3108) Remove an useless negation in registerServiceWorker.js (#3150) Remove output.path from dev webpack config (#3158) Add `.mjs` support (#3239) Add documentation for Enzyme 3 integration (#3286) Make uglify work in Safari 10.0 - fixes #3280 (#3281) Fix favicon sizes value in manifest (#3287) Bump dependencies (#3342) recommend react-snap; react-snapshot isn't upgraded for React 16 (#3328) Update appveyor.cleanup-cache.txt Polyfill rAF in test environment (#3340) Use React 16 in development Use a simpler string replacement for the overlay Clarify the npm precompilation advice --no-edit Update `eslint-plugin-react` (#3146) Add jest coverage configuration docs (#3279) Update link to Jest Expect docs (#3303) Update README.md Fix dead link to Jest "expect" docs (#3289) v2.8.0 Use production React version for bundled overlay (#3267) Add warning when using `react-error-overlay` in production (#3264) Add external links to deployment services (#3265) `react-error-overlay` has no dependencies now (#3263) Add click-to-open support for build errors (#3100) Update style-loader and disable inclusion of its HMR code in builds (#3236) Update url-loader to 0.6.2 for mime ReDoS vuln (#3246) Make error overlay to run in the context of the iframe (#3142) Upgrade to typescript 2.5.3 Fix Windows compatibility (#3232) Fix package management link in README (#3227) Watch for changes in `src/**/node_modules` (#3230) More spec compliant HTML template (#2914) Minor change to highlight dev proxy behaviour (#3075) Correct manual proxy documentation (#3185) Improve grammar in README (#3211) Publish Fix license comments Changelog for 1.0.14 BSD+Patents -> MIT (#3189) Add link to active CSS modules discussion (#3163) Update webpack-dev-server to 2.8.2 (#3157) Part of class fields to stage 3 (#2908) Update unclear wording in webpack config docs (#3160) Display pid in already running message (#3131) Link local react-error-overlay package in kitchensink test Resolved issue #2971 (#2989) Revert "run npm 5.4.0 in CI (#3026)" (#3107) Updated react-error-overlay to latest Flow (0.54.0) (#3065) Auto-detect running editor on Linux for error overlay (#3077) Clean target directory before compiling overlay (#3102) Rerun prettier and pin version (#3058) ...
This attempts to implement the idea proposed in #3120.
In this implementation, the script(
iframeScript.js
) that needs to be executed in the context of the iframe is bundled in a separate webpack build step. Then this script is imported as a text using webpack raw-loader in the main overlay script(index.js
) and inject to the iframe with a script tag. After the injected script is executed, it starts to communicate with the main script via some global hooks and continue to update overlay until there are no errors to show.Based on #2961, #1944, using inline webpack raw-loader might not be a good idea. Any suggestions on that?