-
Notifications
You must be signed in to change notification settings - Fork 4
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
React v17 support #32
Conversation
@@ -78,10 +85,9 @@ | |||
"prop-types": "^15.5.10", | |||
"querystring": "^0.2.0", | |||
"radium": "^0.25.1", | |||
"react": "^16.0.0", | |||
"react-addons-test-utils": "^15.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.
It looks like you guys have already migrated to using react-dom/test-utils
so this doesn't appear to be needed anymore
}, | ||
"scripts": { | ||
"commit": "git-cz", | ||
"changelog": "conventional-changelog -p angular -i CHANGELOG.md -s", | ||
"build": "npm run clean && npm run compile", | ||
"build:es": "BABEL_ENV=es babel --copy-files ./src -d es", | ||
"build:umd": |
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.
Prettier got a hold of some of this. The only relevant changes are the deps above.
package.json
Outdated
@@ -1,6 +1,6 @@ | |||
{ | |||
"name": "@atmedia/react-gpt", | |||
"version": "2.1.6", | |||
"version": "2.1.7", |
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 just bumped this because 🤷 If we're being semantic, it's probably a major version change.
slotSize, | ||
this.viewableThreshold | ||
); | ||
|
||
const isHidden = () => { | ||
const el = ReactDOM.findDOMNode(this); |
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.
findDOMNode
no longer behaves the way it used to. This looked like the only change needed to get ads rendering. Whether they are rendering correctly I'll leave to you guys ;) at least to tell me that they're broken.
@stephensauceda I can have a look into the failing unit tests. The first of the two is almost certainly from our having made some tweaks to the out of page ads to accommodate the mobile interstitial, and can most likely be fixed by updating the test. Will need to get back to you on the second test which is timing out. I wonder if there's something about this under the |
* update deps * update radium to version supporting react 17 * add prepare script * remove prepare script * findDOMNode is deprecated * make peerDependencies more lenient * ref needs to be on different node * Reverting the version as i will do that in another step --------- Co-authored-by: Andrew Sotiriou <[email protected]>
* Enable non-personalized Ads (#1) * Enable non-personalized Ads According to EU regulations, it is mandatory to enable users to opt-out to tracking cookies GPT allows us to respect this law using the `npa` flag on Ads. * Adding npa flag to re-render props * Fix npa variable in componentWillReceiveProps * Increase the bundle-size to accept the new amount of code * Changed the place where NPA is set * Update Bling.js Fixes an issue where `setAttributes` can be called when there is no ad slot * Bump to 2.0.2 * chore: Update package.json Update package.json name and urls after forking * chore: Update API list Update GPT API list to latest * chore: Add prettier config (#3) Add prettier config and fix bracket spacing mismatch * Fixing things * fix: Don't setState on unmounted ad (#5) Don't set state on an unmounted ad. Cribbed from axioscode@9425436. * fix: Fix undefined function if apiNotReady (#6) Fix undefined function if apiNotReady. Cribbed from ticketmaster@5ef19b1. * fix: Replace hasOwnProperty with more reliable check (#7) Replace hasOwnProperty with more reliable check. Cribbed from nfl@8826ee3. * fix: Do not refresh all ads when new component loads (#8) Fixes an issue where all ad slots would reload when syncCorrelator was true and a new slot was added * refactor: Check for updateCorrelator (#9) Check for deprecated updateCorrelator method before calling * build: Update radium (#10) * build: Update radium Update radium to fix "TypeError: Cannot read property 'object' of undefined" when running examples * Use ^ * Fixing things * fix: Stop multiple refresh on mq change (#11) * fix: Stop multiple refresh on mq change Stops multiple calls to instance.refresh() on media query change. This can happen when an instance is associated with multiple instances. * Only debounce this.refresh * Fix comment * Merge it * feat: Add support for custom refresh function (#14) Adds the ability to specify a custom refresh function using `configure`. This function replaces the call to `pubads().refresh`. This is useful for certain header bidding configurations, such as App Nexus that requires to `pbjs.refresh` to be called. * work this time * perf: Use googletag.cmd.push instead of timeout to process queue (#16) Use googletag.cmd.push instead of timeout to check if pubads is ready. Fixes issue with recurring handler. * work this time * Update all instances of googletagservices gpt url to securepubads gpt url (#20) * Update all instances of googletagservices gpt url to securepubads gpt url * Add UNSAFE so we can look to update REACT * update remaining paths; use https to avoid redirect Co-authored-by: Andrew Berry <[email protected]> * update linking instructions; some cleanup (#21) * remove enableServices timeout from GPT mock (#22) * Release 2.1.2 (#24) * Remove deprecated ContentService (#23) * Remove deprecated ContentService usage * Update test * doc updates Co-authored-by: Andrew Sotiriou <[email protected]> * update changelog and version in package.json (#25) * Ton of MI updates (#26) * Ton of MI updates * Minor changes * change release and update changelog (#27) * Gregt/negative viewable threshold (#28) * Can work with negative viewability threshold. * Offset in log remark is now VT for clarity. * Checking for isNaN * removed logging Co-authored-by: Engywook2005 <[email protected]> * Changed version and updated changelog (#29) * Changed version and updated changelog * Fixed typo in package.json Co-authored-by: Engywook2005 <[email protected]> * Andrew s/neg vt issue (#30) * Fixes for neg VT * Update isHidden * Cleanup * Remove log * Update call * Release 2 1 6 (#31) * update packageJSON version * Update changelog * add prepare script * Revert "add prepare script" This reverts commit 49fcf5b. * React v17 support (#32) * update deps * update radium to version supporting react 17 * add prepare script * remove prepare script * findDOMNode is deprecated * make peerDependencies more lenient * ref needs to be on different node * Reverting the version as i will do that in another step --------- Co-authored-by: Andrew Sotiriou <[email protected]> * release branch (#33) * Remove console log (#34) * Update package and remove console log (#35) * Gregt/lazy load (#36) * Add stuff for lazy load * First shot at ignoring isInViewport response. * Will render ads even if the inviewport check fails * Removed commented out line of code * Version bump and changelog update --------- Co-authored-by: Andrew Sotiriou <[email protected]> Co-authored-by: Greg Thorson <[email protected]> --------- Co-authored-by: Carlos A. Gomes <[email protected]> Co-authored-by: Carlos Gomes <[email protected]> Co-authored-by: Michael Blanchard <[email protected]> Co-authored-by: Mike Kruk <[email protected]> Co-authored-by: Andrew Berry <[email protected]> Co-authored-by: Andrew Berry <[email protected]> Co-authored-by: Greg Thorson <[email protected]> Co-authored-by: Engywook2005 <[email protected]> Co-authored-by: Stephen Sauceda <[email protected]> Co-authored-by: Greg Thorson <[email protected]>
What does this PR do?
Bumps dependencies to support React 17. This is package blocks some of our other apps and services from being able to upgrade due to peerDependencies (namely oxygen and the auth migration).
How can this change be manually tested?
I ran the tests with
yarn test
. It appears two tests are failing. But they appear to be the same two tests that fail onmaster
. Not sure how you guys are rolling with this. Are the tests known failures?To test the ad loading stuff:
react-gpt
directory,yarn
andyarn build
then, runnpm link
s/react17
branchnpm link @atmedia/react-gpt
Asana Card
https://app.asana.com/0/1201709980437746/1203717210397677/f
Questions or concerns about this change?
When I bump the React dependencies to v17, I get a peerDependency warning for Radium. This is a bummer because it looks like it's a package that is no longer supported by the maintainers. They encourage forks, so... I guess we do that?Deployment Notes
Need to resolve the peerDependency on Radium and React v16Radium has React 17 support in 0.26.2PR Readiness
Code Readiness
Automated Testing
Other Considerations
Also consider this PR's impact on architecture and security; AMP, Apple News, RSS; SEO, GA, performance and accessibility.
Please see Post Merge for additional responsibilities after this PR is merged.