From 09914c1db4b2ba10f37b32f6a74236be42dbbd29 Mon Sep 17 00:00:00 2001 From: Michael Jackson Date: Sat, 12 Jan 2019 19:27:28 -0800 Subject: [PATCH] Server render the main page Also, add hashes to asset file names and use the "entry manifest" plugin in dev to get auto-reloading. --- .gitignore | 2 +- .size-snapshot.json | 12 - firebase.json | 1 + functions/package.json | 1 - modules/actions/serveAutoIndexPage.js | 38 +- modules/actions/serveMainPage.js | 32 + modules/client/.babelrc | 9 +- modules/client/MainPage.js | 72 - modules/client/MainTemplate.js | 89 + modules/client/autoIndex.css | 8 - modules/client/autoIndex.js | 22 +- modules/client/autoIndex/App.js | 24 +- modules/client/autoIndex/DirectoryListing.js | 18 +- modules/client/main.css | 63 - modules/client/main.js | 80 +- modules/client/main/App.js | 179 +- modules/client/main/Layout.js | 172 - modules/client/main/Stats.js | 10 +- modules/client/main/WindowSize.js | 10 +- modules/functions/index.js | 2 + modules/functions/serveMainPage.js | 10 + modules/utils/getEntryPoints.js | 19 + .../{renderPage.js => renderTemplate.js} | 4 +- package-lock.json | 3025 +-- package.json | 21 +- plugins/entryManifest.js | 113 + public/autoIndex.css | 8 - public/index.css | 63 - public/index.html | 26 - public/react-dom@16.7.0/LICENSE | 21 - public/react-dom@16.7.0/README.md | 54 - public/react-dom@16.7.0/build-info.json | 8 - .../react-dom-server.browser.development.js | 3576 --- ...react-dom-server.browser.production.min.js | 45 - .../cjs/react-dom-server.node.development.js | 3627 --- .../react-dom-server.node.production.min.js | 47 - .../cjs/react-dom-test-utils.development.js | 1253 - .../react-dom-test-utils.production.min.js | 33 - .../react-dom-unstable-fire.development.js | 20093 --------------- .../react-dom-unstable-fire.production.min.js | 249 - .../react-dom-unstable-fire.profiling.min.js | 261 - ...t-dom-unstable-fizz.browser.development.js | 144 - ...om-unstable-fizz.browser.production.min.js | 11 - ...eact-dom-unstable-fizz.node.development.js | 150 - ...t-dom-unstable-fizz.node.production.min.js | 11 - ...nstable-native-dependencies.development.js | 1676 -- ...able-native-dependencies.production.min.js | 36 - .../cjs/react-dom.development.js | 20085 --------------- .../cjs/react-dom.production.min.js | 249 - .../cjs/react-dom.profiling.min.js | 261 - public/react-dom@16.7.0/index.js | 38 - public/react-dom@16.7.0/package.json | 83 - public/react-dom@16.7.0/profiling.js | 38 - public/react-dom@16.7.0/server.browser.js | 7 - public/react-dom@16.7.0/server.js | 3 - public/react-dom@16.7.0/server.node.js | 7 - public/react-dom@16.7.0/test-utils.js | 7 - .../react-dom-server.browser.development.js | 3681 --- ...react-dom-server.browser.production.min.js | 40 - .../umd/react-dom-test-utils.development.js | 1253 - .../react-dom-test-utils.production.min.js | 28 - .../react-dom-unstable-fire.development.js | 20220 ---------------- .../react-dom-unstable-fire.production.min.js | 207 - .../react-dom-unstable-fire.profiling.min.js | 212 - ...t-dom-unstable-fizz.browser.development.js | 144 - ...om-unstable-fizz.browser.production.min.js | 10 - ...nstable-native-dependencies.development.js | 1677 -- ...able-native-dependencies.production.min.js | 30 - .../umd/react-dom.development.js | 20212 --------------- .../umd/react-dom.production.min.js | 207 - .../umd/react-dom.profiling.min.js | 212 - .../react-dom@16.7.0/unstable-fizz.browser.js | 7 - public/react-dom@16.7.0/unstable-fizz.js | 3 - public/react-dom@16.7.0/unstable-fizz.node.js | 7 - .../unstable-native-dependencies.js | 7 - public/react-motion@0.5.2/AUTHORS | 40 - public/react-motion@0.5.2/HISTORY.md | 99 - public/react-motion@0.5.2/LICENSE | 22 - public/react-motion@0.5.2/README.md | 310 - public/react-motion@0.5.2/bower.json | 41 - .../react-motion@0.5.2/build/react-motion.js | 2821 --- .../react-motion@0.5.2/build/react-motion.map | 1 - public/react-motion@0.5.2/lib/Motion.js | 267 - public/react-motion@0.5.2/lib/Motion.js.flow | 237 - .../react-motion@0.5.2/lib/StaggeredMotion.js | 288 - .../lib/StaggeredMotion.js.flow | 257 - .../lib/TransitionMotion.js | 522 - .../lib/TransitionMotion.js.flow | 549 - public/react-motion@0.5.2/lib/Types.js | 35 - public/react-motion@0.5.2/lib/Types.js.flow | 72 - public/react-motion@0.5.2/lib/mapToZero.js | 19 - .../react-motion@0.5.2/lib/mapToZero.js.flow | 13 - public/react-motion@0.5.2/lib/mergeDiff.js | 108 - .../react-motion@0.5.2/lib/mergeDiff.js.flow | 105 - public/react-motion@0.5.2/lib/presets.js | 10 - public/react-motion@0.5.2/lib/presets.js.flow | 7 - public/react-motion@0.5.2/lib/react-motion.js | 35 - .../lib/react-motion.js.flow | 10 - public/react-motion@0.5.2/lib/reorderKeys.js | 17 - .../lib/reorderKeys.js.flow | 13 - .../lib/shouldStopAnimation.js | 31 - .../lib/shouldStopAnimation.js.flow | 31 - public/react-motion@0.5.2/lib/spring.js | 23 - public/react-motion@0.5.2/lib/spring.js.flow | 12 - public/react-motion@0.5.2/lib/stepper.js | 43 - public/react-motion@0.5.2/lib/stepper.js.flow | 42 - public/react-motion@0.5.2/lib/stripStyle.js | 21 - .../react-motion@0.5.2/lib/stripStyle.js.flow | 16 - public/react-motion@0.5.2/package.json | 231 - .../react-router-dom@4.3.1/BrowserRouter.js | 67 - public/react-router-dom@4.3.1/HashRouter.js | 66 - public/react-router-dom@4.3.1/Link.js | 117 - public/react-router-dom@4.3.1/MemoryRouter.js | 11 - public/react-router-dom@4.3.1/NavLink.js | 91 - public/react-router-dom@4.3.1/Prompt.js | 11 - public/react-router-dom@4.3.1/README.md | 37 - public/react-router-dom@4.3.1/Redirect.js | 11 - public/react-router-dom@4.3.1/Route.js | 11 - public/react-router-dom@4.3.1/Router.js | 11 - public/react-router-dom@4.3.1/StaticRouter.js | 11 - public/react-router-dom@4.3.1/Switch.js | 11 - .../es/BrowserRouter.js | 52 - .../react-router-dom@4.3.1/es/HashRouter.js | 51 - public/react-router-dom@4.3.1/es/Link.js | 104 - .../react-router-dom@4.3.1/es/MemoryRouter.js | 4 - public/react-router-dom@4.3.1/es/NavLink.js | 74 - public/react-router-dom@4.3.1/es/Prompt.js | 4 - public/react-router-dom@4.3.1/es/Redirect.js | 4 - public/react-router-dom@4.3.1/es/Route.js | 4 - public/react-router-dom@4.3.1/es/Router.js | 4 - .../es/RouterContext.js | 4 - .../react-router-dom@4.3.1/es/StaticRouter.js | 4 - public/react-router-dom@4.3.1/es/Switch.js | 4 - .../react-router-dom@4.3.1/es/generatePath.js | 4 - public/react-router-dom@4.3.1/es/index.js | 28 - public/react-router-dom@4.3.1/es/matchPath.js | 4 - .../react-router-dom@4.3.1/es/withRouter.js | 4 - public/react-router-dom@4.3.1/generatePath.js | 11 - public/react-router-dom@4.3.1/index.js | 77 - public/react-router-dom@4.3.1/matchPath.js | 11 - public/react-router-dom@4.3.1/package.json | 131 - .../umd/react-router-dom.js | 3788 --- .../umd/react-router-dom.min.js | 1 - public/react-router-dom@4.3.1/withRouter.js | 11 - public/react@16.7.0/LICENSE | 21 - public/react@16.7.0/README.md | 13 - public/react@16.7.0/build-info.json | 8 - public/react@16.7.0/cjs/react.development.js | 1883 -- .../react@16.7.0/cjs/react.production.min.js | 24 - public/react@16.7.0/index.js | 7 - public/react@16.7.0/package.json | 66 - public/react@16.7.0/umd/react.development.js | 3098 --- .../react@16.7.0/umd/react.production.min.js | 31 - .../react@16.7.0/umd/react.profiling.min.js | 35 - public/systemjs@2.0.0/LICENSE | 10 + public/systemjs@2.0.0/README.md | 179 + public/systemjs@2.0.0/dist/extras/amd.js | 116 + public/systemjs@2.0.0/dist/extras/amd.min.js | 1 + .../systemjs@2.0.0/dist/extras/amd.min.js.map | 1 + public/systemjs@2.0.0/dist/extras/global.js | 57 + .../systemjs@2.0.0/dist/extras/global.min.js | 1 + .../dist/extras/global.min.js.map | 1 + .../dist/extras/named-exports.js | 48 + .../dist/extras/named-exports.min.js | 1 + .../dist/extras/named-exports.min.js.map | 1 + .../systemjs@2.0.0/dist/extras/transform.js | 32 + .../dist/extras/transform.min.js | 1 + .../dist/extras/transform.min.js.map | 1 + public/systemjs@2.0.0/dist/s.js | 403 + public/systemjs@2.0.0/dist/s.min.js | 1 + public/systemjs@2.0.0/dist/s.min.js.map | 1 + public/systemjs@2.0.0/dist/system.js | 712 + public/systemjs@2.0.0/dist/system.min.js | 4 + public/systemjs@2.0.0/dist/system.min.js.map | 1 + public/systemjs@2.0.0/package.json | 76 + rollup.config.js | 164 +- 176 files changed, 2725 insertions(+), 119822 deletions(-) delete mode 100644 .size-snapshot.json create mode 100644 modules/actions/serveMainPage.js delete mode 100644 modules/client/MainPage.js create mode 100644 modules/client/MainTemplate.js delete mode 100644 modules/client/autoIndex.css delete mode 100644 modules/client/main.css delete mode 100644 modules/client/main/Layout.js create mode 100644 modules/functions/serveMainPage.js create mode 100644 modules/utils/getEntryPoints.js rename modules/utils/{renderPage.js => renderTemplate.js} (50%) create mode 100644 plugins/entryManifest.js delete mode 100644 public/autoIndex.css delete mode 100644 public/index.css delete mode 100644 public/index.html delete mode 100644 public/react-dom@16.7.0/LICENSE delete mode 100644 public/react-dom@16.7.0/README.md delete mode 100644 public/react-dom@16.7.0/build-info.json delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-server.browser.development.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-server.browser.production.min.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-server.node.development.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-server.node.production.min.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-test-utils.development.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-test-utils.production.min.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-unstable-fire.development.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-unstable-fire.production.min.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-unstable-fire.profiling.min.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-unstable-fizz.browser.development.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-unstable-fizz.browser.production.min.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-unstable-fizz.node.development.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-unstable-fizz.node.production.min.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-unstable-native-dependencies.development.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom-unstable-native-dependencies.production.min.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom.development.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom.production.min.js delete mode 100644 public/react-dom@16.7.0/cjs/react-dom.profiling.min.js delete mode 100644 public/react-dom@16.7.0/index.js delete mode 100644 public/react-dom@16.7.0/package.json delete mode 100644 public/react-dom@16.7.0/profiling.js delete mode 100644 public/react-dom@16.7.0/server.browser.js delete mode 100644 public/react-dom@16.7.0/server.js delete mode 100644 public/react-dom@16.7.0/server.node.js delete mode 100644 public/react-dom@16.7.0/test-utils.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-server.browser.development.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-server.browser.production.min.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-test-utils.development.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-test-utils.production.min.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-unstable-fire.development.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-unstable-fire.production.min.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-unstable-fire.profiling.min.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-unstable-fizz.browser.development.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-unstable-fizz.browser.production.min.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-unstable-native-dependencies.development.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom-unstable-native-dependencies.production.min.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom.development.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom.production.min.js delete mode 100644 public/react-dom@16.7.0/umd/react-dom.profiling.min.js delete mode 100644 public/react-dom@16.7.0/unstable-fizz.browser.js delete mode 100644 public/react-dom@16.7.0/unstable-fizz.js delete mode 100644 public/react-dom@16.7.0/unstable-fizz.node.js delete mode 100644 public/react-dom@16.7.0/unstable-native-dependencies.js delete mode 100644 public/react-motion@0.5.2/AUTHORS delete mode 100644 public/react-motion@0.5.2/HISTORY.md delete mode 100644 public/react-motion@0.5.2/LICENSE delete mode 100644 public/react-motion@0.5.2/README.md delete mode 100644 public/react-motion@0.5.2/bower.json delete mode 100644 public/react-motion@0.5.2/build/react-motion.js delete mode 100644 public/react-motion@0.5.2/build/react-motion.map delete mode 100644 public/react-motion@0.5.2/lib/Motion.js delete mode 100644 public/react-motion@0.5.2/lib/Motion.js.flow delete mode 100644 public/react-motion@0.5.2/lib/StaggeredMotion.js delete mode 100644 public/react-motion@0.5.2/lib/StaggeredMotion.js.flow delete mode 100644 public/react-motion@0.5.2/lib/TransitionMotion.js delete mode 100644 public/react-motion@0.5.2/lib/TransitionMotion.js.flow delete mode 100644 public/react-motion@0.5.2/lib/Types.js delete mode 100644 public/react-motion@0.5.2/lib/Types.js.flow delete mode 100644 public/react-motion@0.5.2/lib/mapToZero.js delete mode 100644 public/react-motion@0.5.2/lib/mapToZero.js.flow delete mode 100644 public/react-motion@0.5.2/lib/mergeDiff.js delete mode 100644 public/react-motion@0.5.2/lib/mergeDiff.js.flow delete mode 100644 public/react-motion@0.5.2/lib/presets.js delete mode 100644 public/react-motion@0.5.2/lib/presets.js.flow delete mode 100644 public/react-motion@0.5.2/lib/react-motion.js delete mode 100644 public/react-motion@0.5.2/lib/react-motion.js.flow delete mode 100644 public/react-motion@0.5.2/lib/reorderKeys.js delete mode 100644 public/react-motion@0.5.2/lib/reorderKeys.js.flow delete mode 100644 public/react-motion@0.5.2/lib/shouldStopAnimation.js delete mode 100644 public/react-motion@0.5.2/lib/shouldStopAnimation.js.flow delete mode 100644 public/react-motion@0.5.2/lib/spring.js delete mode 100644 public/react-motion@0.5.2/lib/spring.js.flow delete mode 100644 public/react-motion@0.5.2/lib/stepper.js delete mode 100644 public/react-motion@0.5.2/lib/stepper.js.flow delete mode 100644 public/react-motion@0.5.2/lib/stripStyle.js delete mode 100644 public/react-motion@0.5.2/lib/stripStyle.js.flow delete mode 100644 public/react-motion@0.5.2/package.json delete mode 100644 public/react-router-dom@4.3.1/BrowserRouter.js delete mode 100644 public/react-router-dom@4.3.1/HashRouter.js delete mode 100644 public/react-router-dom@4.3.1/Link.js delete mode 100644 public/react-router-dom@4.3.1/MemoryRouter.js delete mode 100644 public/react-router-dom@4.3.1/NavLink.js delete mode 100644 public/react-router-dom@4.3.1/Prompt.js delete mode 100644 public/react-router-dom@4.3.1/README.md delete mode 100644 public/react-router-dom@4.3.1/Redirect.js delete mode 100644 public/react-router-dom@4.3.1/Route.js delete mode 100644 public/react-router-dom@4.3.1/Router.js delete mode 100644 public/react-router-dom@4.3.1/StaticRouter.js delete mode 100644 public/react-router-dom@4.3.1/Switch.js delete mode 100644 public/react-router-dom@4.3.1/es/BrowserRouter.js delete mode 100644 public/react-router-dom@4.3.1/es/HashRouter.js delete mode 100644 public/react-router-dom@4.3.1/es/Link.js delete mode 100644 public/react-router-dom@4.3.1/es/MemoryRouter.js delete mode 100644 public/react-router-dom@4.3.1/es/NavLink.js delete mode 100644 public/react-router-dom@4.3.1/es/Prompt.js delete mode 100644 public/react-router-dom@4.3.1/es/Redirect.js delete mode 100644 public/react-router-dom@4.3.1/es/Route.js delete mode 100644 public/react-router-dom@4.3.1/es/Router.js delete mode 100644 public/react-router-dom@4.3.1/es/RouterContext.js delete mode 100644 public/react-router-dom@4.3.1/es/StaticRouter.js delete mode 100644 public/react-router-dom@4.3.1/es/Switch.js delete mode 100644 public/react-router-dom@4.3.1/es/generatePath.js delete mode 100644 public/react-router-dom@4.3.1/es/index.js delete mode 100644 public/react-router-dom@4.3.1/es/matchPath.js delete mode 100644 public/react-router-dom@4.3.1/es/withRouter.js delete mode 100644 public/react-router-dom@4.3.1/generatePath.js delete mode 100644 public/react-router-dom@4.3.1/index.js delete mode 100644 public/react-router-dom@4.3.1/matchPath.js delete mode 100644 public/react-router-dom@4.3.1/package.json delete mode 100644 public/react-router-dom@4.3.1/umd/react-router-dom.js delete mode 100644 public/react-router-dom@4.3.1/umd/react-router-dom.min.js delete mode 100644 public/react-router-dom@4.3.1/withRouter.js delete mode 100644 public/react@16.7.0/LICENSE delete mode 100644 public/react@16.7.0/README.md delete mode 100644 public/react@16.7.0/build-info.json delete mode 100644 public/react@16.7.0/cjs/react.development.js delete mode 100644 public/react@16.7.0/cjs/react.production.min.js delete mode 100644 public/react@16.7.0/index.js delete mode 100644 public/react@16.7.0/package.json delete mode 100644 public/react@16.7.0/umd/react.development.js delete mode 100644 public/react@16.7.0/umd/react.production.min.js delete mode 100644 public/react@16.7.0/umd/react.profiling.min.js create mode 100644 public/systemjs@2.0.0/LICENSE create mode 100644 public/systemjs@2.0.0/README.md create mode 100644 public/systemjs@2.0.0/dist/extras/amd.js create mode 100644 public/systemjs@2.0.0/dist/extras/amd.min.js create mode 100644 public/systemjs@2.0.0/dist/extras/amd.min.js.map create mode 100644 public/systemjs@2.0.0/dist/extras/global.js create mode 100644 public/systemjs@2.0.0/dist/extras/global.min.js create mode 100644 public/systemjs@2.0.0/dist/extras/global.min.js.map create mode 100644 public/systemjs@2.0.0/dist/extras/named-exports.js create mode 100644 public/systemjs@2.0.0/dist/extras/named-exports.min.js create mode 100644 public/systemjs@2.0.0/dist/extras/named-exports.min.js.map create mode 100644 public/systemjs@2.0.0/dist/extras/transform.js create mode 100644 public/systemjs@2.0.0/dist/extras/transform.min.js create mode 100644 public/systemjs@2.0.0/dist/extras/transform.min.js.map create mode 100644 public/systemjs@2.0.0/dist/s.js create mode 100644 public/systemjs@2.0.0/dist/s.min.js create mode 100644 public/systemjs@2.0.0/dist/s.min.js.map create mode 100644 public/systemjs@2.0.0/dist/system.js create mode 100644 public/systemjs@2.0.0/dist/system.min.js create mode 100644 public/systemjs@2.0.0/dist/system.min.js.map create mode 100644 public/systemjs@2.0.0/package.json diff --git a/.gitignore b/.gitignore index 5d0c7bb..6307126 100644 --- a/.gitignore +++ b/.gitignore @@ -7,7 +7,7 @@ npm-debug.log* /functions/*.js /functions/node_modules/ /node_modules/ -/public/_assets/ +/public/_client/ /manifest.json /secret_key /tokens/ diff --git a/.size-snapshot.json b/.size-snapshot.json deleted file mode 100644 index 1e0dcb2..0000000 --- a/.size-snapshot.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "public/_assets/main.js": { - "bundled": 106911, - "minified": 41169, - "gzipped": 13005 - }, - "public/_assets/autoIndex.js": { - "bundled": 44017, - "minified": 15077, - "gzipped": 5142 - } -} diff --git a/firebase.json b/firebase.json index f95f529..e7756f9 100644 --- a/firebase.json +++ b/firebase.json @@ -6,6 +6,7 @@ { "source": "/api/auth", "function": "serveAuth" }, { "source": "/api/public-key", "function": "servePublicKey" }, { "source": "/api/stats", "function": "serveStats" }, + { "source": "/", "function": "serveMainPage" }, { "source": "**/", "function": "serveAutoIndexPage" }, { "source": "**", "function": "serveNpmPackageFile" } ] diff --git a/functions/package.json b/functions/package.json index 226a02f..f746936 100644 --- a/functions/package.json +++ b/functions/package.json @@ -42,7 +42,6 @@ "warning": "^4.0.2", "whatwg-url": "^7.0.0" }, - "devDependencies": {}, "engines": { "node": "8" } diff --git a/modules/actions/serveAutoIndexPage.js b/modules/actions/serveAutoIndexPage.js index bede8b4..87401dc 100644 --- a/modules/actions/serveAutoIndexPage.js +++ b/modules/actions/serveAutoIndexPage.js @@ -2,31 +2,18 @@ import React from 'react'; import ReactDOMServer from 'react-dom/server'; import semver from 'semver'; -import MainPage from '../client/MainPage'; +import MainTemplate from '../client/MainTemplate'; import AutoIndexApp from '../client/autoIndex/App'; import createHTML from '../client/utils/createHTML'; -import renderPage from '../utils/renderPage'; - -const globalScripts = - process.env.NODE_ENV === 'production' - ? [ - '/react@16.7.0/umd/react.production.min.js', - '/react-dom@16.7.0/umd/react-dom.production.min.js' - ] - : [ - '/react@16.7.0/umd/react.development.js', - '/react-dom@16.7.0/umd/react-dom.development.js' - ]; +import getEntryPoints from '../utils/getEntryPoints'; +import renderTemplate from '../utils/renderTemplate'; function byVersion(a, b) { return semver.lt(a, b) ? -1 : semver.gt(a, b) ? 1 : 0; } export default function serveAutoIndexPage(req, res) { - const scripts = globalScripts.concat('/_assets/autoIndex.js'); - const styles = ['/autoIndex.css']; - - const props = { + const data = { packageName: req.packageName, packageVersion: req.packageVersion, availableVersions: Object.keys(req.packageInfo.versions).sort(byVersion), @@ -34,17 +21,22 @@ export default function serveAutoIndexPage(req, res) { entry: req.entry, entries: req.entries }; + const content = createHTML( - ReactDOMServer.renderToString(React.createElement(AutoIndexApp, props)) + ReactDOMServer.renderToString(React.createElement(AutoIndexApp, data)) ); - const html = renderPage(MainPage, { + const entryPoints = getEntryPoints('autoIndex', { + es: 'module', + system: 'nomodule' + }); + + const html = renderTemplate(MainTemplate, { title: `UNPKG - ${req.packageName}`, description: `The CDN for ${req.packageName}`, - scripts: scripts, - styles: styles, - data: props, - content: content + data, + content, + entryPoints }); res diff --git a/modules/actions/serveMainPage.js b/modules/actions/serveMainPage.js new file mode 100644 index 0000000..b0c2ab1 --- /dev/null +++ b/modules/actions/serveMainPage.js @@ -0,0 +1,32 @@ +import React from 'react'; +import ReactDOMServer from 'react-dom/server'; +import { StaticRouter } from 'react-router-dom'; + +import MainTemplate from '../client/MainTemplate'; +import MainApp from '../client/main/App'; +import createHTML from '../client/utils/createHTML'; +import getEntryPoints from '../utils/getEntryPoints'; +import renderTemplate from '../utils/renderTemplate'; + +export default function serveMainPage(req, res) { + const element = React.createElement( + StaticRouter, + { location: req.url }, + React.createElement(MainApp) + ); + const content = createHTML(ReactDOMServer.renderToString(element)); + + const entryPoints = getEntryPoints('main', { + es: 'module', + system: 'nomodule' + }); + + const html = renderTemplate(MainTemplate, { content, entryPoints }); + + res + .set({ + 'Cache-Control': 'public, max-age=14400', // 4 hours + 'Cache-Tag': 'main' + }) + .send(html); +} diff --git a/modules/client/.babelrc b/modules/client/.babelrc index 36371d2..4a8e5ca 100644 --- a/modules/client/.babelrc +++ b/modules/client/.babelrc @@ -1,4 +1,9 @@ { - "presets": [["@babel/env", { "loose": true }], "@babel/react"], - "plugins": [["@babel/plugin-proposal-class-properties", { "loose": true }]] + "presets": [ + ["@babel/env", { "loose": true }], + "@babel/react" + ], + "plugins": [ + ["@babel/plugin-proposal-class-properties", { "loose": true }] + ] } diff --git a/modules/client/MainPage.js b/modules/client/MainPage.js deleted file mode 100644 index f101bf2..0000000 --- a/modules/client/MainPage.js +++ /dev/null @@ -1,72 +0,0 @@ -import React from 'react'; -import PropTypes from 'prop-types'; - -import createHTML from './utils/createHTML'; -import x from './utils/execScript'; - -export default function MainPage({ - title, - description, - favicon, - scripts, - styles, - data, - content -}) { - return ( - - - - - {description && } - - - {favicon && } - {styles.map(s => ( - - ))} - {x( - 'window.Promise || document.write(\'\\x3Cscript src="/_polyfills/es6-promise.min.js">\\x3C/script>\\x3Cscript>ES6Promise.polyfill()\\x3C/script>\')' - )} - {x( - 'window.fetch || document.write(\'\\x3Cscript src="/_polyfills/fetch.min.js">\\x3C/script>\')' - )} - {x(`window.__DATA__ = ${JSON.stringify(data)}`)} - {title} - - -
- {scripts.map(s => ( - - - UNPKG - - - -
- - - - - - - diff --git a/public/react-dom@16.7.0/LICENSE b/public/react-dom@16.7.0/LICENSE deleted file mode 100644 index b96dcb0..0000000 --- a/public/react-dom@16.7.0/LICENSE +++ /dev/null @@ -1,21 +0,0 @@ -MIT License - -Copyright (c) Facebook, Inc. and its affiliates. - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. diff --git a/public/react-dom@16.7.0/README.md b/public/react-dom@16.7.0/README.md deleted file mode 100644 index 2652912..0000000 --- a/public/react-dom@16.7.0/README.md +++ /dev/null @@ -1,54 +0,0 @@ -# `react-dom` - -This package serves as the entry point to the DOM and server renderers for React. It is intended to be paired with the generic React package, which is shipped as `react` to npm. - -## Installation - -```sh -npm install react react-dom -``` - -## Usage - -### In the browser - -```js -var React = require('react'); -var ReactDOM = require('react-dom'); - -class MyComponent extends React.Component { - render() { - return
Hello World
; - } -} - -ReactDOM.render(, node); -``` - -### On the server - -```js -var React = require('react'); -var ReactDOMServer = require('react-dom/server'); - -class MyComponent extends React.Component { - render() { - return
Hello World
; - } -} - -ReactDOMServer.renderToString(); -``` - -## API - -### `react-dom` - -- `findDOMNode` -- `render` -- `unmountComponentAtNode` - -### `react-dom/server` - -- `renderToString` -- `renderToStaticMarkup` diff --git a/public/react-dom@16.7.0/build-info.json b/public/react-dom@16.7.0/build-info.json deleted file mode 100644 index a7ae896..0000000 --- a/public/react-dom@16.7.0/build-info.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "branch": "master", - "buildNumber": "12928", - "checksum": "7d45248", - "commit": "4a1072194", - "environment": "ci", - "reactVersion": "16.6.1-canary-4a1072194" -} diff --git a/public/react-dom@16.7.0/cjs/react-dom-server.browser.development.js b/public/react-dom@16.7.0/cjs/react-dom-server.browser.development.js deleted file mode 100644 index a8c5053..0000000 --- a/public/react-dom@16.7.0/cjs/react-dom-server.browser.development.js +++ /dev/null @@ -1,3576 +0,0 @@ -/** @license React v16.7.0 - * react-dom-server.browser.development.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -'use strict'; - - - -if (process.env.NODE_ENV !== "production") { - (function() { -'use strict'; - -var _assign = require('object-assign'); -var React = require('react'); -var checkPropTypes = require('prop-types/checkPropTypes'); - -/** - * Use invariant() to assert state which your program assumes to be true. - * - * Provide sprintf-style format (only %s is supported) and arguments - * to provide information about what broke and what you were - * expecting. - * - * The invariant message will be stripped in production, but the invariant - * will remain to ensure logic does not differ in production. - */ - -var validateFormat = function () {}; - -{ - validateFormat = function (format) { - if (format === undefined) { - throw new Error('invariant requires an error message argument'); - } - }; -} - -function invariant(condition, format, a, b, c, d, e, f) { - validateFormat(format); - - if (!condition) { - var error = void 0; - if (format === undefined) { - error = new Error('Minified exception occurred; use the non-minified dev environment ' + 'for the full error message and additional helpful warnings.'); - } else { - var args = [a, b, c, d, e, f]; - var argIndex = 0; - error = new Error(format.replace(/%s/g, function () { - return args[argIndex++]; - })); - error.name = 'Invariant Violation'; - } - - error.framesToPop = 1; // we don't care about invariant's own frame - throw error; - } -} - -// Relying on the `invariant()` implementation lets us -// preserve the format and params in the www builds. - -// TODO: this is special because it gets imported during build. - -var ReactVersion = '16.7.0'; - -/** - * Similar to invariant but only logs a warning if the condition is not met. - * This can be used to log issues in development environments in critical - * paths. Removing the logging code for production environments will keep the - * same logic and follow the same code paths. - */ - -var warningWithoutStack = function () {}; - -{ - warningWithoutStack = function (condition, format) { - for (var _len = arguments.length, args = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { - args[_key - 2] = arguments[_key]; - } - - if (format === undefined) { - throw new Error('`warningWithoutStack(condition, format, ...args)` requires a warning ' + 'message argument'); - } - if (args.length > 8) { - // Check before the condition to catch violations early. - throw new Error('warningWithoutStack() currently supports at most 8 arguments.'); - } - if (condition) { - return; - } - if (typeof console !== 'undefined') { - var argsWithFormat = args.map(function (item) { - return '' + item; - }); - argsWithFormat.unshift('Warning: ' + format); - - // We intentionally don't use spread (or .apply) directly because it - // breaks IE9: https://github.com/facebook/react/issues/13610 - Function.prototype.apply.call(console.error, console, argsWithFormat); - } - try { - // --- Welcome to debugging React --- - // This error was thrown as a convenience so that you can use this stack - // to find the callsite that caused this warning to fire. - var argIndex = 0; - var message = 'Warning: ' + format.replace(/%s/g, function () { - return args[argIndex++]; - }); - throw new Error(message); - } catch (x) {} - }; -} - -var warningWithoutStack$1 = warningWithoutStack; - -// The Symbol used to tag the ReactElement-like types. If there is no native Symbol -// nor polyfill, then a plain number is used for performance. -var hasSymbol = typeof Symbol === 'function' && Symbol.for; - - -var REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 0xeaca; -var REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 0xeacb; -var REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 0xeacc; -var REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 0xead2; -var REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 0xeacd; -var REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 0xeace; - -var REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 0xeacf; -var REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 0xead0; -var REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 0xead1; -var REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 0xead3; -var REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 0xead4; - -var Resolved = 1; - - -function refineResolvedLazyComponent(lazyComponent) { - return lazyComponent._status === Resolved ? lazyComponent._result : null; -} - -function getWrappedName(outerType, innerType, wrapperName) { - var functionName = innerType.displayName || innerType.name || ''; - return outerType.displayName || (functionName !== '' ? wrapperName + '(' + functionName + ')' : wrapperName); -} - -function getComponentName(type) { - if (type == null) { - // Host root, text node or just invalid type. - return null; - } - { - if (typeof type.tag === 'number') { - warningWithoutStack$1(false, 'Received an unexpected object in getComponentName(). ' + 'This is likely a bug in React. Please file an issue.'); - } - } - if (typeof type === 'function') { - return type.displayName || type.name || null; - } - if (typeof type === 'string') { - return type; - } - switch (type) { - case REACT_CONCURRENT_MODE_TYPE: - return 'ConcurrentMode'; - case REACT_FRAGMENT_TYPE: - return 'Fragment'; - case REACT_PORTAL_TYPE: - return 'Portal'; - case REACT_PROFILER_TYPE: - return 'Profiler'; - case REACT_STRICT_MODE_TYPE: - return 'StrictMode'; - case REACT_SUSPENSE_TYPE: - return 'Suspense'; - } - if (typeof type === 'object') { - switch (type.$$typeof) { - case REACT_CONTEXT_TYPE: - return 'Context.Consumer'; - case REACT_PROVIDER_TYPE: - return 'Context.Provider'; - case REACT_FORWARD_REF_TYPE: - return getWrappedName(type, type.render, 'ForwardRef'); - case REACT_MEMO_TYPE: - return getComponentName(type.type); - case REACT_LAZY_TYPE: - { - var thenable = type; - var resolvedThenable = refineResolvedLazyComponent(thenable); - if (resolvedThenable) { - return getComponentName(resolvedThenable); - } - } - } - } - return null; -} - -/** - * Forked from fbjs/warning: - * https://github.com/facebook/fbjs/blob/e66ba20ad5be433eb54423f2b097d829324d9de6/packages/fbjs/src/__forks__/warning.js - * - * Only change is we use console.warn instead of console.error, - * and do nothing when 'console' is not supported. - * This really simplifies the code. - * --- - * Similar to invariant but only logs a warning if the condition is not met. - * This can be used to log issues in development environments in critical - * paths. Removing the logging code for production environments will keep the - * same logic and follow the same code paths. - */ - -var lowPriorityWarning = function () {}; - -{ - var printWarning = function (format) { - for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - var argIndex = 0; - var message = 'Warning: ' + format.replace(/%s/g, function () { - return args[argIndex++]; - }); - if (typeof console !== 'undefined') { - console.warn(message); - } - try { - // --- Welcome to debugging React --- - // This error was thrown as a convenience so that you can use this stack - // to find the callsite that caused this warning to fire. - throw new Error(message); - } catch (x) {} - }; - - lowPriorityWarning = function (condition, format) { - if (format === undefined) { - throw new Error('`lowPriorityWarning(condition, format, ...args)` requires a warning ' + 'message argument'); - } - if (!condition) { - for (var _len2 = arguments.length, args = Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) { - args[_key2 - 2] = arguments[_key2]; - } - - printWarning.apply(undefined, [format].concat(args)); - } - }; -} - -var lowPriorityWarning$1 = lowPriorityWarning; - -var ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED; - -/** - * Similar to invariant but only logs a warning if the condition is not met. - * This can be used to log issues in development environments in critical - * paths. Removing the logging code for production environments will keep the - * same logic and follow the same code paths. - */ - -var warning = warningWithoutStack$1; - -{ - warning = function (condition, format) { - if (condition) { - return; - } - var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame; - var stack = ReactDebugCurrentFrame.getStackAddendum(); - // eslint-disable-next-line react-internal/warning-and-invariant-args - - for (var _len = arguments.length, args = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { - args[_key - 2] = arguments[_key]; - } - - warningWithoutStack$1.apply(undefined, [false, format + '%s'].concat(args, [stack])); - }; -} - -var warning$1 = warning; - -var BEFORE_SLASH_RE = /^(.*)[\\\/]/; - -var describeComponentFrame = function (name, source, ownerName) { - var sourceInfo = ''; - if (source) { - var path = source.fileName; - var fileName = path.replace(BEFORE_SLASH_RE, ''); - { - // In DEV, include code for a common special case: - // prefer "folder/index.js" instead of just "index.js". - if (/^index\./.test(fileName)) { - var match = path.match(BEFORE_SLASH_RE); - if (match) { - var pathBeforeSlash = match[1]; - if (pathBeforeSlash) { - var folderName = pathBeforeSlash.replace(BEFORE_SLASH_RE, ''); - fileName = folderName + '/' + fileName; - } - } - } - } - sourceInfo = ' (at ' + fileName + ':' + source.lineNumber + ')'; - } else if (ownerName) { - sourceInfo = ' (created by ' + ownerName + ')'; - } - return '\n in ' + (name || 'Unknown') + sourceInfo; -}; - -var enableHooks = false; -// Helps identify side effects in begin-phase lifecycle hooks and setState reducers: - - -// In some cases, StrictMode should also double-render lifecycles. -// This can be confusing for tests though, -// And it can be bad for performance in production. -// This feature flag can be used to control the behavior: - - -// To preserve the "Pause on caught exceptions" behavior of the debugger, we -// replay the begin phase of a failed component inside invokeGuardedCallback. - - -// Warn about deprecated, async-unsafe lifecycles; relates to RFC #6: -var warnAboutDeprecatedLifecycles = false; - -// Gather advanced timing metrics for Profiler subtrees. - - -// Trace which interactions trigger each commit. - - -// Only used in www builds. -var enableSuspenseServerRenderer = false; // TODO: true? Here it might just be false. - -// Only used in www builds. - - -// Only used in www builds. - - -// React Fire: prevent the value and checked attributes from syncing -// with their related DOM properties - - -// These APIs will no longer be "unstable" in the upcoming 16.7 release, -// Control this behavior with a flag to support 16.6 minor releases in the meanwhile. - -var ReactDebugCurrentFrame$1 = void 0; -{ - ReactDebugCurrentFrame$1 = ReactSharedInternals.ReactDebugCurrentFrame; -} - -var didWarnAboutInvalidateContextType = {}; - -var emptyObject = {}; -{ - Object.freeze(emptyObject); -} - -function maskContext(type, context) { - var contextTypes = type.contextTypes; - if (!contextTypes) { - return emptyObject; - } - var maskedContext = {}; - for (var contextName in contextTypes) { - maskedContext[contextName] = context[contextName]; - } - return maskedContext; -} - -function checkContextTypes(typeSpecs, values, location) { - { - checkPropTypes(typeSpecs, values, location, 'Component', ReactDebugCurrentFrame$1.getCurrentStack); - } -} - -function validateContextBounds(context, threadID) { - // If we don't have enough slots in this context to store this threadID, - // fill it in without leaving any holes to ensure that the VM optimizes - // this as non-holey index properties. - // (Note: If `react` package is < 16.6, _threadCount is undefined.) - for (var i = context._threadCount | 0; i <= threadID; i++) { - // We assume that this is the same as the defaultValue which might not be - // true if we're rendering inside a secondary renderer but they are - // secondary because these use cases are very rare. - context[i] = context._currentValue2; - context._threadCount = i + 1; - } -} - -function processContext(type, context, threadID) { - var contextType = type.contextType; - if (typeof contextType === 'object' && contextType !== null) { - { - if (contextType.$$typeof !== REACT_CONTEXT_TYPE) { - var name = getComponentName(type) || 'Component'; - if (!didWarnAboutInvalidateContextType[name]) { - didWarnAboutInvalidateContextType[name] = true; - warningWithoutStack$1(false, '%s defines an invalid contextType. ' + 'contextType should point to the Context object returned by React.createContext(). ' + 'Did you accidentally pass the Context.Provider instead?', name); - } - } - } - validateContextBounds(contextType, threadID); - return contextType[threadID]; - } else { - var maskedContext = maskContext(type, context); - { - if (type.contextTypes) { - checkContextTypes(type.contextTypes, maskedContext, 'context'); - } - } - return maskedContext; - } -} - -// Allocates a new index for each request. Tries to stay as compact as possible so that these -// indices can be used to reference a tightly packaged array. As opposed to being used in a Map. -// The first allocated index is 1. - -var nextAvailableThreadIDs = new Uint16Array(16); -for (var i = 0; i < 15; i++) { - nextAvailableThreadIDs[i] = i + 1; -} -nextAvailableThreadIDs[15] = 0; - -function growThreadCountAndReturnNextAvailable() { - var oldArray = nextAvailableThreadIDs; - var oldSize = oldArray.length; - var newSize = oldSize * 2; - !(newSize <= 0x10000) ? invariant(false, 'Maximum number of concurrent React renderers exceeded. This can happen if you are not properly destroying the Readable provided by React. Ensure that you call .destroy() on it if you no longer want to read from it, and did not read to the end. If you use .pipe() this should be automatic.') : void 0; - var newArray = new Uint16Array(newSize); - newArray.set(oldArray); - nextAvailableThreadIDs = newArray; - nextAvailableThreadIDs[0] = oldSize + 1; - for (var _i = oldSize; _i < newSize - 1; _i++) { - nextAvailableThreadIDs[_i] = _i + 1; - } - nextAvailableThreadIDs[newSize - 1] = 0; - return oldSize; -} - -function allocThreadID() { - var nextID = nextAvailableThreadIDs[0]; - if (nextID === 0) { - return growThreadCountAndReturnNextAvailable(); - } - nextAvailableThreadIDs[0] = nextAvailableThreadIDs[nextID]; - return nextID; -} - -function freeThreadID(id) { - nextAvailableThreadIDs[id] = nextAvailableThreadIDs[0]; - nextAvailableThreadIDs[0] = id; -} - -// A reserved attribute. -// It is handled by React separately and shouldn't be written to the DOM. -var RESERVED = 0; - -// A simple string attribute. -// Attributes that aren't in the whitelist are presumed to have this type. -var STRING = 1; - -// A string attribute that accepts booleans in React. In HTML, these are called -// "enumerated" attributes with "true" and "false" as possible values. -// When true, it should be set to a "true" string. -// When false, it should be set to a "false" string. -var BOOLEANISH_STRING = 2; - -// A real boolean attribute. -// When true, it should be present (set either to an empty string or its name). -// When false, it should be omitted. -var BOOLEAN = 3; - -// An attribute that can be used as a flag as well as with a value. -// When true, it should be present (set either to an empty string or its name). -// When false, it should be omitted. -// For any other value, should be present with that value. -var OVERLOADED_BOOLEAN = 4; - -// An attribute that must be numeric or parse as a numeric. -// When falsy, it should be removed. -var NUMERIC = 5; - -// An attribute that must be positive numeric or parse as a positive numeric. -// When falsy, it should be removed. -var POSITIVE_NUMERIC = 6; - -/* eslint-disable max-len */ -var ATTRIBUTE_NAME_START_CHAR = ':A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD'; -/* eslint-enable max-len */ -var ATTRIBUTE_NAME_CHAR = ATTRIBUTE_NAME_START_CHAR + '\\-.0-9\\u00B7\\u0300-\\u036F\\u203F-\\u2040'; - - -var ROOT_ATTRIBUTE_NAME = 'data-reactroot'; -var VALID_ATTRIBUTE_NAME_REGEX = new RegExp('^[' + ATTRIBUTE_NAME_START_CHAR + '][' + ATTRIBUTE_NAME_CHAR + ']*$'); - -var hasOwnProperty$1 = Object.prototype.hasOwnProperty; -var illegalAttributeNameCache = {}; -var validatedAttributeNameCache = {}; - -function isAttributeNameSafe(attributeName) { - if (hasOwnProperty$1.call(validatedAttributeNameCache, attributeName)) { - return true; - } - if (hasOwnProperty$1.call(illegalAttributeNameCache, attributeName)) { - return false; - } - if (VALID_ATTRIBUTE_NAME_REGEX.test(attributeName)) { - validatedAttributeNameCache[attributeName] = true; - return true; - } - illegalAttributeNameCache[attributeName] = true; - { - warning$1(false, 'Invalid attribute name: `%s`', attributeName); - } - return false; -} - -function shouldIgnoreAttribute(name, propertyInfo, isCustomComponentTag) { - if (propertyInfo !== null) { - return propertyInfo.type === RESERVED; - } - if (isCustomComponentTag) { - return false; - } - if (name.length > 2 && (name[0] === 'o' || name[0] === 'O') && (name[1] === 'n' || name[1] === 'N')) { - return true; - } - return false; -} - -function shouldRemoveAttributeWithWarning(name, value, propertyInfo, isCustomComponentTag) { - if (propertyInfo !== null && propertyInfo.type === RESERVED) { - return false; - } - switch (typeof value) { - case 'function': - // $FlowIssue symbol is perfectly valid here - case 'symbol': - // eslint-disable-line - return true; - case 'boolean': - { - if (isCustomComponentTag) { - return false; - } - if (propertyInfo !== null) { - return !propertyInfo.acceptsBooleans; - } else { - var prefix = name.toLowerCase().slice(0, 5); - return prefix !== 'data-' && prefix !== 'aria-'; - } - } - default: - return false; - } -} - -function shouldRemoveAttribute(name, value, propertyInfo, isCustomComponentTag) { - if (value === null || typeof value === 'undefined') { - return true; - } - if (shouldRemoveAttributeWithWarning(name, value, propertyInfo, isCustomComponentTag)) { - return true; - } - if (isCustomComponentTag) { - return false; - } - if (propertyInfo !== null) { - switch (propertyInfo.type) { - case BOOLEAN: - return !value; - case OVERLOADED_BOOLEAN: - return value === false; - case NUMERIC: - return isNaN(value); - case POSITIVE_NUMERIC: - return isNaN(value) || value < 1; - } - } - return false; -} - -function getPropertyInfo(name) { - return properties.hasOwnProperty(name) ? properties[name] : null; -} - -function PropertyInfoRecord(name, type, mustUseProperty, attributeName, attributeNamespace) { - this.acceptsBooleans = type === BOOLEANISH_STRING || type === BOOLEAN || type === OVERLOADED_BOOLEAN; - this.attributeName = attributeName; - this.attributeNamespace = attributeNamespace; - this.mustUseProperty = mustUseProperty; - this.propertyName = name; - this.type = type; -} - -// When adding attributes to this list, be sure to also add them to -// the `possibleStandardNames` module to ensure casing and incorrect -// name warnings. -var properties = {}; - -// These props are reserved by React. They shouldn't be written to the DOM. -['children', 'dangerouslySetInnerHTML', -// TODO: This prevents the assignment of defaultValue to regular -// elements (not just inputs). Now that ReactDOMInput assigns to the -// defaultValue property -- do we need this? -'defaultValue', 'defaultChecked', 'innerHTML', 'suppressContentEditableWarning', 'suppressHydrationWarning', 'style'].forEach(function (name) { - properties[name] = new PropertyInfoRecord(name, RESERVED, false, // mustUseProperty - name, // attributeName - null); -} // attributeNamespace -); - -// A few React string attributes have a different name. -// This is a mapping from React prop names to the attribute names. -[['acceptCharset', 'accept-charset'], ['className', 'class'], ['htmlFor', 'for'], ['httpEquiv', 'http-equiv']].forEach(function (_ref) { - var name = _ref[0], - attributeName = _ref[1]; - - properties[name] = new PropertyInfoRecord(name, STRING, false, // mustUseProperty - attributeName, // attributeName - null); -} // attributeNamespace -); - -// These are "enumerated" HTML attributes that accept "true" and "false". -// In React, we let users pass `true` and `false` even though technically -// these aren't boolean attributes (they are coerced to strings). -['contentEditable', 'draggable', 'spellCheck', 'value'].forEach(function (name) { - properties[name] = new PropertyInfoRecord(name, BOOLEANISH_STRING, false, // mustUseProperty - name.toLowerCase(), // attributeName - null); -} // attributeNamespace -); - -// These are "enumerated" SVG attributes that accept "true" and "false". -// In React, we let users pass `true` and `false` even though technically -// these aren't boolean attributes (they are coerced to strings). -// Since these are SVG attributes, their attribute names are case-sensitive. -['autoReverse', 'externalResourcesRequired', 'focusable', 'preserveAlpha'].forEach(function (name) { - properties[name] = new PropertyInfoRecord(name, BOOLEANISH_STRING, false, // mustUseProperty - name, // attributeName - null); -} // attributeNamespace -); - -// These are HTML boolean attributes. -['allowFullScreen', 'async', -// Note: there is a special case that prevents it from being written to the DOM -// on the client side because the browsers are inconsistent. Instead we call focus(). -'autoFocus', 'autoPlay', 'controls', 'default', 'defer', 'disabled', 'formNoValidate', 'hidden', 'loop', 'noModule', 'noValidate', 'open', 'playsInline', 'readOnly', 'required', 'reversed', 'scoped', 'seamless', -// Microdata -'itemScope'].forEach(function (name) { - properties[name] = new PropertyInfoRecord(name, BOOLEAN, false, // mustUseProperty - name.toLowerCase(), // attributeName - null); -} // attributeNamespace -); - -// These are the few React props that we set as DOM properties -// rather than attributes. These are all booleans. -['checked', -// Note: `option.selected` is not updated if `select.multiple` is -// disabled with `removeAttribute`. We have special logic for handling this. -'multiple', 'muted', 'selected'].forEach(function (name) { - properties[name] = new PropertyInfoRecord(name, BOOLEAN, true, // mustUseProperty - name, // attributeName - null); -} // attributeNamespace -); - -// These are HTML attributes that are "overloaded booleans": they behave like -// booleans, but can also accept a string value. -['capture', 'download'].forEach(function (name) { - properties[name] = new PropertyInfoRecord(name, OVERLOADED_BOOLEAN, false, // mustUseProperty - name, // attributeName - null); -} // attributeNamespace -); - -// These are HTML attributes that must be positive numbers. -['cols', 'rows', 'size', 'span'].forEach(function (name) { - properties[name] = new PropertyInfoRecord(name, POSITIVE_NUMERIC, false, // mustUseProperty - name, // attributeName - null); -} // attributeNamespace -); - -// These are HTML attributes that must be numbers. -['rowSpan', 'start'].forEach(function (name) { - properties[name] = new PropertyInfoRecord(name, NUMERIC, false, // mustUseProperty - name.toLowerCase(), // attributeName - null); -} // attributeNamespace -); - -var CAMELIZE = /[\-\:]([a-z])/g; -var capitalize = function (token) { - return token[1].toUpperCase(); -}; - -// This is a list of all SVG attributes that need special casing, namespacing, -// or boolean value assignment. Regular attributes that just accept strings -// and have the same names are omitted, just like in the HTML whitelist. -// Some of these attributes can be hard to find. This list was created by -// scrapping the MDN documentation. -['accent-height', 'alignment-baseline', 'arabic-form', 'baseline-shift', 'cap-height', 'clip-path', 'clip-rule', 'color-interpolation', 'color-interpolation-filters', 'color-profile', 'color-rendering', 'dominant-baseline', 'enable-background', 'fill-opacity', 'fill-rule', 'flood-color', 'flood-opacity', 'font-family', 'font-size', 'font-size-adjust', 'font-stretch', 'font-style', 'font-variant', 'font-weight', 'glyph-name', 'glyph-orientation-horizontal', 'glyph-orientation-vertical', 'horiz-adv-x', 'horiz-origin-x', 'image-rendering', 'letter-spacing', 'lighting-color', 'marker-end', 'marker-mid', 'marker-start', 'overline-position', 'overline-thickness', 'paint-order', 'panose-1', 'pointer-events', 'rendering-intent', 'shape-rendering', 'stop-color', 'stop-opacity', 'strikethrough-position', 'strikethrough-thickness', 'stroke-dasharray', 'stroke-dashoffset', 'stroke-linecap', 'stroke-linejoin', 'stroke-miterlimit', 'stroke-opacity', 'stroke-width', 'text-anchor', 'text-decoration', 'text-rendering', 'underline-position', 'underline-thickness', 'unicode-bidi', 'unicode-range', 'units-per-em', 'v-alphabetic', 'v-hanging', 'v-ideographic', 'v-mathematical', 'vector-effect', 'vert-adv-y', 'vert-origin-x', 'vert-origin-y', 'word-spacing', 'writing-mode', 'xmlns:xlink', 'x-height'].forEach(function (attributeName) { - var name = attributeName.replace(CAMELIZE, capitalize); - properties[name] = new PropertyInfoRecord(name, STRING, false, // mustUseProperty - attributeName, null); -} // attributeNamespace -); - -// String SVG attributes with the xlink namespace. -['xlink:actuate', 'xlink:arcrole', 'xlink:href', 'xlink:role', 'xlink:show', 'xlink:title', 'xlink:type'].forEach(function (attributeName) { - var name = attributeName.replace(CAMELIZE, capitalize); - properties[name] = new PropertyInfoRecord(name, STRING, false, // mustUseProperty - attributeName, 'http://www.w3.org/1999/xlink'); -}); - -// String SVG attributes with the xml namespace. -['xml:base', 'xml:lang', 'xml:space'].forEach(function (attributeName) { - var name = attributeName.replace(CAMELIZE, capitalize); - properties[name] = new PropertyInfoRecord(name, STRING, false, // mustUseProperty - attributeName, 'http://www.w3.org/XML/1998/namespace'); -}); - -// Special case: this attribute exists both in HTML and SVG. -// Its "tabindex" attribute name is case-sensitive in SVG so we can't just use -// its React `tabIndex` name, like we do for attributes that exist only in HTML. -properties.tabIndex = new PropertyInfoRecord('tabIndex', STRING, false, // mustUseProperty -'tabindex', // attributeName -null); - -// code copied and modified from escape-html -/** - * Module variables. - * @private - */ - -var matchHtmlRegExp = /["'&<>]/; - -/** - * Escapes special characters and HTML entities in a given html string. - * - * @param {string} string HTML string to escape for later insertion - * @return {string} - * @public - */ - -function escapeHtml(string) { - var str = '' + string; - var match = matchHtmlRegExp.exec(str); - - if (!match) { - return str; - } - - var escape = void 0; - var html = ''; - var index = void 0; - var lastIndex = 0; - - for (index = match.index; index < str.length; index++) { - switch (str.charCodeAt(index)) { - case 34: - // " - escape = '"'; - break; - case 38: - // & - escape = '&'; - break; - case 39: - // ' - escape = '''; // modified from escape-html; used to be ''' - break; - case 60: - // < - escape = '<'; - break; - case 62: - // > - escape = '>'; - break; - default: - continue; - } - - if (lastIndex !== index) { - html += str.substring(lastIndex, index); - } - - lastIndex = index + 1; - html += escape; - } - - return lastIndex !== index ? html + str.substring(lastIndex, index) : html; -} -// end code copied and modified from escape-html - -/** - * Escapes text to prevent scripting attacks. - * - * @param {*} text Text value to escape. - * @return {string} An escaped string. - */ -function escapeTextForBrowser(text) { - if (typeof text === 'boolean' || typeof text === 'number') { - // this shortcircuit helps perf for types that we know will never have - // special characters, especially given that this function is used often - // for numeric dom ids. - return '' + text; - } - return escapeHtml(text); -} - -/** - * Escapes attribute value to prevent scripting attacks. - * - * @param {*} value Value to escape. - * @return {string} An escaped string. - */ -function quoteAttributeValueForBrowser(value) { - return '"' + escapeTextForBrowser(value) + '"'; -} - -/** - * Operations for dealing with DOM properties. - */ - -/** - * Creates markup for the ID property. - * - * @param {string} id Unescaped ID. - * @return {string} Markup string. - */ - - -function createMarkupForRoot() { - return ROOT_ATTRIBUTE_NAME + '=""'; -} - -/** - * Creates markup for a property. - * - * @param {string} name - * @param {*} value - * @return {?string} Markup string, or null if the property was invalid. - */ -function createMarkupForProperty(name, value) { - var propertyInfo = getPropertyInfo(name); - if (name !== 'style' && shouldIgnoreAttribute(name, propertyInfo, false)) { - return ''; - } - if (shouldRemoveAttribute(name, value, propertyInfo, false)) { - return ''; - } - if (propertyInfo !== null) { - var attributeName = propertyInfo.attributeName; - var type = propertyInfo.type; - - if (type === BOOLEAN || type === OVERLOADED_BOOLEAN && value === true) { - return attributeName + '=""'; - } else { - return attributeName + '=' + quoteAttributeValueForBrowser(value); - } - } else if (isAttributeNameSafe(name)) { - return name + '=' + quoteAttributeValueForBrowser(value); - } - return ''; -} - -/** - * Creates markup for a custom property. - * - * @param {string} name - * @param {*} value - * @return {string} Markup string, or empty string if the property was invalid. - */ -function createMarkupForCustomAttribute(name, value) { - if (!isAttributeNameSafe(name) || value == null) { - return ''; - } - return name + '=' + quoteAttributeValueForBrowser(value); -} - -function areHookInputsEqual(arr1, arr2) { - // Don't bother comparing lengths in prod because these arrays should be - // passed inline. - { - !(arr1.length === arr2.length) ? warning$1(false, 'Detected a variable number of hook dependencies. The length of the ' + 'dependencies array should be constant between renders.\n\n' + 'Previous: %s\n' + 'Incoming: %s', arr1.join(', '), arr2.join(', ')) : void 0; - } - for (var i = 0; i < arr1.length; i++) { - // Inlined Object.is polyfill. - // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is - var val1 = arr1[i]; - var val2 = arr2[i]; - if (val1 === val2 && (val1 !== 0 || 1 / val1 === 1 / val2) || val1 !== val1 && val2 !== val2 // eslint-disable-line no-self-compare - ) { - continue; - } - return false; - } - return true; -} - -var currentlyRenderingComponent = null; -var firstWorkInProgressHook = null; -var workInProgressHook = null; -// Whether the work-in-progress hook is a re-rendered hook -var isReRender = false; -// Whether an update was scheduled during the currently executing render pass. -var didScheduleRenderPhaseUpdate = false; -// Lazily created map of render-phase updates -var renderPhaseUpdates = null; -// Counter to prevent infinite loops. -var numberOfReRenders = 0; -var RE_RENDER_LIMIT = 25; - -function resolveCurrentlyRenderingComponent() { - !(currentlyRenderingComponent !== null) ? invariant(false, 'Hooks can only be called inside the body of a function component.') : void 0; - return currentlyRenderingComponent; -} - -function createHook() { - return { - memoizedState: null, - queue: null, - next: null - }; -} - -function createWorkInProgressHook() { - if (workInProgressHook === null) { - // This is the first hook in the list - if (firstWorkInProgressHook === null) { - isReRender = false; - firstWorkInProgressHook = workInProgressHook = createHook(); - } else { - // There's already a work-in-progress. Reuse it. - isReRender = true; - workInProgressHook = firstWorkInProgressHook; - } - } else { - if (workInProgressHook.next === null) { - isReRender = false; - // Append to the end of the list - workInProgressHook = workInProgressHook.next = createHook(); - } else { - // There's already a work-in-progress. Reuse it. - isReRender = true; - workInProgressHook = workInProgressHook.next; - } - } - return workInProgressHook; -} - -function prepareToUseHooks(componentIdentity) { - currentlyRenderingComponent = componentIdentity; - - // The following should have already been reset - // didScheduleRenderPhaseUpdate = false; - // firstWorkInProgressHook = null; - // numberOfReRenders = 0; - // renderPhaseUpdates = null; - // workInProgressHook = null; -} - -function finishHooks(Component, props, children, refOrContext) { - // This must be called after every function component to prevent hooks from - // being used in classes. - - while (didScheduleRenderPhaseUpdate) { - // Updates were scheduled during the render phase. They are stored in - // the `renderPhaseUpdates` map. Call the component again, reusing the - // work-in-progress hooks and applying the additional updates on top. Keep - // restarting until no more updates are scheduled. - didScheduleRenderPhaseUpdate = false; - numberOfReRenders += 1; - - // Start over from the beginning of the list - workInProgressHook = null; - - children = Component(props, refOrContext); - } - currentlyRenderingComponent = null; - firstWorkInProgressHook = null; - numberOfReRenders = 0; - renderPhaseUpdates = null; - workInProgressHook = null; - - // These were reset above - // currentlyRenderingComponent = null; - // didScheduleRenderPhaseUpdate = false; - // firstWorkInProgressHook = null; - // numberOfReRenders = 0; - // renderPhaseUpdates = null; - // workInProgressHook = null; - - return children; -} - -function readContext(context, observedBits) { - var threadID = currentThreadID; - validateContextBounds(context, threadID); - return context[threadID]; -} - -function useContext(context, observedBits) { - resolveCurrentlyRenderingComponent(); - var threadID = currentThreadID; - validateContextBounds(context, threadID); - return context[threadID]; -} - -function basicStateReducer(state, action) { - return typeof action === 'function' ? action(state) : action; -} - -function useState(initialState) { - return useReducer(basicStateReducer, - // useReducer has a special case to support lazy useState initializers - initialState); -} - -function useReducer(reducer, initialState, initialAction) { - currentlyRenderingComponent = resolveCurrentlyRenderingComponent(); - workInProgressHook = createWorkInProgressHook(); - if (isReRender) { - // This is a re-render. Apply the new render phase updates to the previous - var _queue = workInProgressHook.queue; - var _dispatch = _queue.dispatch; - if (renderPhaseUpdates !== null) { - // Render phase updates are stored in a map of queue -> linked list - var firstRenderPhaseUpdate = renderPhaseUpdates.get(_queue); - if (firstRenderPhaseUpdate !== undefined) { - renderPhaseUpdates.delete(_queue); - var newState = workInProgressHook.memoizedState; - var update = firstRenderPhaseUpdate; - do { - // Process this render phase update. We don't have to check the - // priority because it will always be the same as the current - // render's. - var _action = update.action; - newState = reducer(newState, _action); - update = update.next; - } while (update !== null); - - workInProgressHook.memoizedState = newState; - - return [newState, _dispatch]; - } - } - return [workInProgressHook.memoizedState, _dispatch]; - } else { - if (reducer === basicStateReducer) { - // Special case for `useState`. - if (typeof initialState === 'function') { - initialState = initialState(); - } - } else if (initialAction !== undefined && initialAction !== null) { - initialState = reducer(initialState, initialAction); - } - workInProgressHook.memoizedState = initialState; - var _queue2 = workInProgressHook.queue = { - last: null, - dispatch: null - }; - var _dispatch2 = _queue2.dispatch = dispatchAction.bind(null, currentlyRenderingComponent, _queue2); - return [workInProgressHook.memoizedState, _dispatch2]; - } -} - -function useMemo(nextCreate, inputs) { - currentlyRenderingComponent = resolveCurrentlyRenderingComponent(); - workInProgressHook = createWorkInProgressHook(); - - var nextInputs = inputs !== undefined && inputs !== null ? inputs : [nextCreate]; - - if (workInProgressHook !== null && workInProgressHook.memoizedState !== null) { - var prevState = workInProgressHook.memoizedState; - var prevInputs = prevState[1]; - if (areHookInputsEqual(nextInputs, prevInputs)) { - return prevState[0]; - } - } - - var nextValue = nextCreate(); - workInProgressHook.memoizedState = [nextValue, nextInputs]; - return nextValue; -} - -function useRef(initialValue) { - currentlyRenderingComponent = resolveCurrentlyRenderingComponent(); - workInProgressHook = createWorkInProgressHook(); - var previousRef = workInProgressHook.memoizedState; - if (previousRef === null) { - var ref = { current: initialValue }; - { - Object.seal(ref); - } - workInProgressHook.memoizedState = ref; - return ref; - } else { - return previousRef; - } -} - -function useLayoutEffect(create, inputs) { - warning$1(false, 'useLayoutEffect does nothing on the server, because its effect cannot ' + "be encoded into the server renderer's output format. This will lead " + 'to a mismatch between the initial, non-hydrated UI and the intended ' + 'UI. To avoid this, useLayoutEffect should only be used in ' + 'components that render exclusively on the client.'); -} - -function dispatchAction(componentIdentity, queue, action) { - !(numberOfReRenders < RE_RENDER_LIMIT) ? invariant(false, 'Too many re-renders. React limits the number of renders to prevent an infinite loop.') : void 0; - - if (componentIdentity === currentlyRenderingComponent) { - // This is a render phase update. Stash it in a lazily-created map of - // queue -> linked list of updates. After this render pass, we'll restart - // and apply the stashed updates on top of the work-in-progress hook. - didScheduleRenderPhaseUpdate = true; - var update = { - action: action, - next: null - }; - if (renderPhaseUpdates === null) { - renderPhaseUpdates = new Map(); - } - var firstRenderPhaseUpdate = renderPhaseUpdates.get(queue); - if (firstRenderPhaseUpdate === undefined) { - renderPhaseUpdates.set(queue, update); - } else { - // Append the update to the end of the list. - var lastRenderPhaseUpdate = firstRenderPhaseUpdate; - while (lastRenderPhaseUpdate.next !== null) { - lastRenderPhaseUpdate = lastRenderPhaseUpdate.next; - } - lastRenderPhaseUpdate.next = update; - } - } else { - // This means an update has happened after the function component has - // returned. On the server this is a no-op. In React Fiber, the update - // would be scheduled for a future render. - } -} - -function noop() {} -function identity(fn) { - return fn; -} - -var currentThreadID = 0; - -function setCurrentThreadID(threadID) { - currentThreadID = threadID; -} - -var Dispatcher = { - readContext: readContext, - useContext: useContext, - useMemo: useMemo, - useReducer: useReducer, - useRef: useRef, - useState: useState, - useLayoutEffect: useLayoutEffect, - // Callbacks are passed as they are in the server environment. - useCallback: identity, - // useImperativeMethods is not run in the server environment - useImperativeMethods: noop, - // Effects are not run in the server environment. - useEffect: noop -}; -var DispatcherWithoutHooks = { - readContext: readContext -}; - -var HTML_NAMESPACE = 'http://www.w3.org/1999/xhtml'; -var MATH_NAMESPACE = 'http://www.w3.org/1998/Math/MathML'; -var SVG_NAMESPACE = 'http://www.w3.org/2000/svg'; - -var Namespaces = { - html: HTML_NAMESPACE, - mathml: MATH_NAMESPACE, - svg: SVG_NAMESPACE -}; - -// Assumes there is no parent namespace. -function getIntrinsicNamespace(type) { - switch (type) { - case 'svg': - return SVG_NAMESPACE; - case 'math': - return MATH_NAMESPACE; - default: - return HTML_NAMESPACE; - } -} - -function getChildNamespace(parentNamespace, type) { - if (parentNamespace == null || parentNamespace === HTML_NAMESPACE) { - // No (or default) parent namespace: potential entry point. - return getIntrinsicNamespace(type); - } - if (parentNamespace === SVG_NAMESPACE && type === 'foreignObject') { - // We're leaving SVG. - return HTML_NAMESPACE; - } - // By default, pass namespace below. - return parentNamespace; -} - -var ReactDebugCurrentFrame$2 = null; - -var ReactControlledValuePropTypes = { - checkPropTypes: null -}; - -{ - ReactDebugCurrentFrame$2 = ReactSharedInternals.ReactDebugCurrentFrame; - - var hasReadOnlyValue = { - button: true, - checkbox: true, - image: true, - hidden: true, - radio: true, - reset: true, - submit: true - }; - - var propTypes = { - value: function (props, propName, componentName) { - if (hasReadOnlyValue[props.type] || props.onChange || props.readOnly || props.disabled || props[propName] == null) { - return null; - } - return new Error('You provided a `value` prop to a form field without an ' + '`onChange` handler. This will render a read-only field. If ' + 'the field should be mutable use `defaultValue`. Otherwise, ' + 'set either `onChange` or `readOnly`.'); - }, - checked: function (props, propName, componentName) { - if (props.onChange || props.readOnly || props.disabled || props[propName] == null) { - return null; - } - return new Error('You provided a `checked` prop to a form field without an ' + '`onChange` handler. This will render a read-only field. If ' + 'the field should be mutable use `defaultChecked`. Otherwise, ' + 'set either `onChange` or `readOnly`.'); - } - }; - - /** - * Provide a linked `value` attribute for controlled forms. You should not use - * this outside of the ReactDOM controlled form components. - */ - ReactControlledValuePropTypes.checkPropTypes = function (tagName, props) { - checkPropTypes(propTypes, props, 'prop', tagName, ReactDebugCurrentFrame$2.getStackAddendum); - }; -} - -// For HTML, certain tags should omit their close tag. We keep a whitelist for -// those special-case tags. - -var omittedCloseTags = { - area: true, - base: true, - br: true, - col: true, - embed: true, - hr: true, - img: true, - input: true, - keygen: true, - link: true, - meta: true, - param: true, - source: true, - track: true, - wbr: true - // NOTE: menuitem's close tag should be omitted, but that causes problems. -}; - -// For HTML, certain tags cannot have children. This has the same purpose as -// `omittedCloseTags` except that `menuitem` should still have its closing tag. - -var voidElementTags = _assign({ - menuitem: true -}, omittedCloseTags); - -// TODO: We can remove this if we add invariantWithStack() -// or add stack by default to invariants where possible. -var HTML = '__html'; - -var ReactDebugCurrentFrame$3 = null; -{ - ReactDebugCurrentFrame$3 = ReactSharedInternals.ReactDebugCurrentFrame; -} - -function assertValidProps(tag, props) { - if (!props) { - return; - } - // Note the use of `==` which checks for null or undefined. - if (voidElementTags[tag]) { - !(props.children == null && props.dangerouslySetInnerHTML == null) ? invariant(false, '%s is a void element tag and must neither have `children` nor use `dangerouslySetInnerHTML`.%s', tag, ReactDebugCurrentFrame$3.getStackAddendum()) : void 0; - } - if (props.dangerouslySetInnerHTML != null) { - !(props.children == null) ? invariant(false, 'Can only set one of `children` or `props.dangerouslySetInnerHTML`.') : void 0; - !(typeof props.dangerouslySetInnerHTML === 'object' && HTML in props.dangerouslySetInnerHTML) ? invariant(false, '`props.dangerouslySetInnerHTML` must be in the form `{__html: ...}`. Please visit https://fb.me/react-invariant-dangerously-set-inner-html for more information.') : void 0; - } - { - !(props.suppressContentEditableWarning || !props.contentEditable || props.children == null) ? warning$1(false, 'A component is `contentEditable` and contains `children` managed by ' + 'React. It is now your responsibility to guarantee that none of ' + 'those nodes are unexpectedly modified or duplicated. This is ' + 'probably not intentional.') : void 0; - } - !(props.style == null || typeof props.style === 'object') ? invariant(false, 'The `style` prop expects a mapping from style properties to values, not a string. For example, style={{marginRight: spacing + \'em\'}} when using JSX.%s', ReactDebugCurrentFrame$3.getStackAddendum()) : void 0; -} - -/** - * CSS properties which accept numbers but are not in units of "px". - */ -var isUnitlessNumber = { - animationIterationCount: true, - borderImageOutset: true, - borderImageSlice: true, - borderImageWidth: true, - boxFlex: true, - boxFlexGroup: true, - boxOrdinalGroup: true, - columnCount: true, - columns: true, - flex: true, - flexGrow: true, - flexPositive: true, - flexShrink: true, - flexNegative: true, - flexOrder: true, - gridArea: true, - gridRow: true, - gridRowEnd: true, - gridRowSpan: true, - gridRowStart: true, - gridColumn: true, - gridColumnEnd: true, - gridColumnSpan: true, - gridColumnStart: true, - fontWeight: true, - lineClamp: true, - lineHeight: true, - opacity: true, - order: true, - orphans: true, - tabSize: true, - widows: true, - zIndex: true, - zoom: true, - - // SVG-related properties - fillOpacity: true, - floodOpacity: true, - stopOpacity: true, - strokeDasharray: true, - strokeDashoffset: true, - strokeMiterlimit: true, - strokeOpacity: true, - strokeWidth: true -}; - -/** - * @param {string} prefix vendor-specific prefix, eg: Webkit - * @param {string} key style name, eg: transitionDuration - * @return {string} style name prefixed with `prefix`, properly camelCased, eg: - * WebkitTransitionDuration - */ -function prefixKey(prefix, key) { - return prefix + key.charAt(0).toUpperCase() + key.substring(1); -} - -/** - * Support style names that may come passed in prefixed by adding permutations - * of vendor prefixes. - */ -var prefixes = ['Webkit', 'ms', 'Moz', 'O']; - -// Using Object.keys here, or else the vanilla for-in loop makes IE8 go into an -// infinite loop, because it iterates over the newly added props too. -Object.keys(isUnitlessNumber).forEach(function (prop) { - prefixes.forEach(function (prefix) { - isUnitlessNumber[prefixKey(prefix, prop)] = isUnitlessNumber[prop]; - }); -}); - -/** - * Convert a value into the proper css writable value. The style name `name` - * should be logical (no hyphens), as specified - * in `CSSProperty.isUnitlessNumber`. - * - * @param {string} name CSS property name such as `topMargin`. - * @param {*} value CSS property value such as `10px`. - * @return {string} Normalized style value with dimensions applied. - */ -function dangerousStyleValue(name, value, isCustomProperty) { - // Note that we've removed escapeTextForBrowser() calls here since the - // whole string will be escaped when the attribute is injected into - // the markup. If you provide unsafe user data here they can inject - // arbitrary CSS which may be problematic (I couldn't repro this): - // https://www.owasp.org/index.php/XSS_Filter_Evasion_Cheat_Sheet - // http://www.thespanner.co.uk/2007/11/26/ultimate-xss-css-injection/ - // This is not an XSS hole but instead a potential CSS injection issue - // which has lead to a greater discussion about how we're going to - // trust URLs moving forward. See #2115901 - - var isEmpty = value == null || typeof value === 'boolean' || value === ''; - if (isEmpty) { - return ''; - } - - if (!isCustomProperty && typeof value === 'number' && value !== 0 && !(isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name])) { - return value + 'px'; // Presumes implicit 'px' suffix for unitless numbers - } - - return ('' + value).trim(); -} - -var uppercasePattern = /([A-Z])/g; -var msPattern = /^ms-/; - -/** - * Hyphenates a camelcased CSS property name, for example: - * - * > hyphenateStyleName('backgroundColor') - * < "background-color" - * > hyphenateStyleName('MozTransition') - * < "-moz-transition" - * > hyphenateStyleName('msTransition') - * < "-ms-transition" - * - * As Modernizr suggests (http://modernizr.com/docs/#prefixed), an `ms` prefix - * is converted to `-ms-`. - */ -function hyphenateStyleName(name) { - return name.replace(uppercasePattern, '-$1').toLowerCase().replace(msPattern, '-ms-'); -} - -function isCustomComponent(tagName, props) { - if (tagName.indexOf('-') === -1) { - return typeof props.is === 'string'; - } - switch (tagName) { - // These are reserved SVG and MathML elements. - // We don't mind this whitelist too much because we expect it to never grow. - // The alternative is to track the namespace in a few places which is convoluted. - // https://w3c.github.io/webcomponents/spec/custom/#custom-elements-core-concepts - case 'annotation-xml': - case 'color-profile': - case 'font-face': - case 'font-face-src': - case 'font-face-uri': - case 'font-face-format': - case 'font-face-name': - case 'missing-glyph': - return false; - default: - return true; - } -} - -var warnValidStyle = function () {}; - -{ - // 'msTransform' is correct, but the other prefixes should be capitalized - var badVendoredStyleNamePattern = /^(?:webkit|moz|o)[A-Z]/; - var msPattern$1 = /^-ms-/; - var hyphenPattern = /-(.)/g; - - // style values shouldn't contain a semicolon - var badStyleValueWithSemicolonPattern = /;\s*$/; - - var warnedStyleNames = {}; - var warnedStyleValues = {}; - var warnedForNaNValue = false; - var warnedForInfinityValue = false; - - var camelize = function (string) { - return string.replace(hyphenPattern, function (_, character) { - return character.toUpperCase(); - }); - }; - - var warnHyphenatedStyleName = function (name) { - if (warnedStyleNames.hasOwnProperty(name) && warnedStyleNames[name]) { - return; - } - - warnedStyleNames[name] = true; - warning$1(false, 'Unsupported style property %s. Did you mean %s?', name, - // As Andi Smith suggests - // (http://www.andismith.com/blog/2012/02/modernizr-prefixed/), an `-ms` prefix - // is converted to lowercase `ms`. - camelize(name.replace(msPattern$1, 'ms-'))); - }; - - var warnBadVendoredStyleName = function (name) { - if (warnedStyleNames.hasOwnProperty(name) && warnedStyleNames[name]) { - return; - } - - warnedStyleNames[name] = true; - warning$1(false, 'Unsupported vendor-prefixed style property %s. Did you mean %s?', name, name.charAt(0).toUpperCase() + name.slice(1)); - }; - - var warnStyleValueWithSemicolon = function (name, value) { - if (warnedStyleValues.hasOwnProperty(value) && warnedStyleValues[value]) { - return; - } - - warnedStyleValues[value] = true; - warning$1(false, "Style property values shouldn't contain a semicolon. " + 'Try "%s: %s" instead.', name, value.replace(badStyleValueWithSemicolonPattern, '')); - }; - - var warnStyleValueIsNaN = function (name, value) { - if (warnedForNaNValue) { - return; - } - - warnedForNaNValue = true; - warning$1(false, '`NaN` is an invalid value for the `%s` css style property.', name); - }; - - var warnStyleValueIsInfinity = function (name, value) { - if (warnedForInfinityValue) { - return; - } - - warnedForInfinityValue = true; - warning$1(false, '`Infinity` is an invalid value for the `%s` css style property.', name); - }; - - warnValidStyle = function (name, value) { - if (name.indexOf('-') > -1) { - warnHyphenatedStyleName(name); - } else if (badVendoredStyleNamePattern.test(name)) { - warnBadVendoredStyleName(name); - } else if (badStyleValueWithSemicolonPattern.test(value)) { - warnStyleValueWithSemicolon(name, value); - } - - if (typeof value === 'number') { - if (isNaN(value)) { - warnStyleValueIsNaN(name, value); - } else if (!isFinite(value)) { - warnStyleValueIsInfinity(name, value); - } - } - }; -} - -var warnValidStyle$1 = warnValidStyle; - -var ariaProperties = { - 'aria-current': 0, // state - 'aria-details': 0, - 'aria-disabled': 0, // state - 'aria-hidden': 0, // state - 'aria-invalid': 0, // state - 'aria-keyshortcuts': 0, - 'aria-label': 0, - 'aria-roledescription': 0, - // Widget Attributes - 'aria-autocomplete': 0, - 'aria-checked': 0, - 'aria-expanded': 0, - 'aria-haspopup': 0, - 'aria-level': 0, - 'aria-modal': 0, - 'aria-multiline': 0, - 'aria-multiselectable': 0, - 'aria-orientation': 0, - 'aria-placeholder': 0, - 'aria-pressed': 0, - 'aria-readonly': 0, - 'aria-required': 0, - 'aria-selected': 0, - 'aria-sort': 0, - 'aria-valuemax': 0, - 'aria-valuemin': 0, - 'aria-valuenow': 0, - 'aria-valuetext': 0, - // Live Region Attributes - 'aria-atomic': 0, - 'aria-busy': 0, - 'aria-live': 0, - 'aria-relevant': 0, - // Drag-and-Drop Attributes - 'aria-dropeffect': 0, - 'aria-grabbed': 0, - // Relationship Attributes - 'aria-activedescendant': 0, - 'aria-colcount': 0, - 'aria-colindex': 0, - 'aria-colspan': 0, - 'aria-controls': 0, - 'aria-describedby': 0, - 'aria-errormessage': 0, - 'aria-flowto': 0, - 'aria-labelledby': 0, - 'aria-owns': 0, - 'aria-posinset': 0, - 'aria-rowcount': 0, - 'aria-rowindex': 0, - 'aria-rowspan': 0, - 'aria-setsize': 0 -}; - -var warnedProperties = {}; -var rARIA = new RegExp('^(aria)-[' + ATTRIBUTE_NAME_CHAR + ']*$'); -var rARIACamel = new RegExp('^(aria)[A-Z][' + ATTRIBUTE_NAME_CHAR + ']*$'); - -var hasOwnProperty$2 = Object.prototype.hasOwnProperty; - -function validateProperty(tagName, name) { - if (hasOwnProperty$2.call(warnedProperties, name) && warnedProperties[name]) { - return true; - } - - if (rARIACamel.test(name)) { - var ariaName = 'aria-' + name.slice(4).toLowerCase(); - var correctName = ariaProperties.hasOwnProperty(ariaName) ? ariaName : null; - - // If this is an aria-* attribute, but is not listed in the known DOM - // DOM properties, then it is an invalid aria-* attribute. - if (correctName == null) { - warning$1(false, 'Invalid ARIA attribute `%s`. ARIA attributes follow the pattern aria-* and must be lowercase.', name); - warnedProperties[name] = true; - return true; - } - // aria-* attributes should be lowercase; suggest the lowercase version. - if (name !== correctName) { - warning$1(false, 'Invalid ARIA attribute `%s`. Did you mean `%s`?', name, correctName); - warnedProperties[name] = true; - return true; - } - } - - if (rARIA.test(name)) { - var lowerCasedName = name.toLowerCase(); - var standardName = ariaProperties.hasOwnProperty(lowerCasedName) ? lowerCasedName : null; - - // If this is an aria-* attribute, but is not listed in the known DOM - // DOM properties, then it is an invalid aria-* attribute. - if (standardName == null) { - warnedProperties[name] = true; - return false; - } - // aria-* attributes should be lowercase; suggest the lowercase version. - if (name !== standardName) { - warning$1(false, 'Unknown ARIA attribute `%s`. Did you mean `%s`?', name, standardName); - warnedProperties[name] = true; - return true; - } - } - - return true; -} - -function warnInvalidARIAProps(type, props) { - var invalidProps = []; - - for (var key in props) { - var isValid = validateProperty(type, key); - if (!isValid) { - invalidProps.push(key); - } - } - - var unknownPropString = invalidProps.map(function (prop) { - return '`' + prop + '`'; - }).join(', '); - - if (invalidProps.length === 1) { - warning$1(false, 'Invalid aria prop %s on <%s> tag. ' + 'For details, see https://fb.me/invalid-aria-prop', unknownPropString, type); - } else if (invalidProps.length > 1) { - warning$1(false, 'Invalid aria props %s on <%s> tag. ' + 'For details, see https://fb.me/invalid-aria-prop', unknownPropString, type); - } -} - -function validateProperties(type, props) { - if (isCustomComponent(type, props)) { - return; - } - warnInvalidARIAProps(type, props); -} - -var didWarnValueNull = false; - -function validateProperties$1(type, props) { - if (type !== 'input' && type !== 'textarea' && type !== 'select') { - return; - } - - if (props != null && props.value === null && !didWarnValueNull) { - didWarnValueNull = true; - if (type === 'select' && props.multiple) { - warning$1(false, '`value` prop on `%s` should not be null. ' + 'Consider using an empty array when `multiple` is set to `true` ' + 'to clear the component or `undefined` for uncontrolled components.', type); - } else { - warning$1(false, '`value` prop on `%s` should not be null. ' + 'Consider using an empty string to clear the component or `undefined` ' + 'for uncontrolled components.', type); - } - } -} - -/** - * Registers plugins so that they can extract and dispatch events. - * - * @see {EventPluginHub} - */ - -/** - * Ordered list of injected plugins. - */ - - -/** - * Mapping from event name to dispatch config - */ - - -/** - * Mapping from registration name to plugin module - */ -var registrationNameModules = {}; - -/** - * Mapping from registration name to event name - */ - - -/** - * Mapping from lowercase registration names to the properly cased version, - * used to warn in the case of missing event handlers. Available - * only in true. - * @type {Object} - */ -var possibleRegistrationNames = {}; -// Trust the developer to only use possibleRegistrationNames in true - -/** - * Injects an ordering of plugins (by plugin name). This allows the ordering - * to be decoupled from injection of the actual plugins so that ordering is - * always deterministic regardless of packaging, on-the-fly injection, etc. - * - * @param {array} InjectedEventPluginOrder - * @internal - * @see {EventPluginHub.injection.injectEventPluginOrder} - */ - - -/** - * Injects plugins to be used by `EventPluginHub`. The plugin names must be - * in the ordering injected by `injectEventPluginOrder`. - * - * Plugins can be injected as part of page initialization or on-the-fly. - * - * @param {object} injectedNamesToPlugins Map from names to plugin modules. - * @internal - * @see {EventPluginHub.injection.injectEventPluginsByName} - */ - -// When adding attributes to the HTML or SVG whitelist, be sure to -// also add them to this module to ensure casing and incorrect name -// warnings. -var possibleStandardNames = { - // HTML - accept: 'accept', - acceptcharset: 'acceptCharset', - 'accept-charset': 'acceptCharset', - accesskey: 'accessKey', - action: 'action', - allowfullscreen: 'allowFullScreen', - alt: 'alt', - as: 'as', - async: 'async', - autocapitalize: 'autoCapitalize', - autocomplete: 'autoComplete', - autocorrect: 'autoCorrect', - autofocus: 'autoFocus', - autoplay: 'autoPlay', - autosave: 'autoSave', - capture: 'capture', - cellpadding: 'cellPadding', - cellspacing: 'cellSpacing', - challenge: 'challenge', - charset: 'charSet', - checked: 'checked', - children: 'children', - cite: 'cite', - class: 'className', - classid: 'classID', - classname: 'className', - cols: 'cols', - colspan: 'colSpan', - content: 'content', - contenteditable: 'contentEditable', - contextmenu: 'contextMenu', - controls: 'controls', - controlslist: 'controlsList', - coords: 'coords', - crossorigin: 'crossOrigin', - dangerouslysetinnerhtml: 'dangerouslySetInnerHTML', - data: 'data', - datetime: 'dateTime', - default: 'default', - defaultchecked: 'defaultChecked', - defaultvalue: 'defaultValue', - defer: 'defer', - dir: 'dir', - disabled: 'disabled', - download: 'download', - draggable: 'draggable', - enctype: 'encType', - for: 'htmlFor', - form: 'form', - formmethod: 'formMethod', - formaction: 'formAction', - formenctype: 'formEncType', - formnovalidate: 'formNoValidate', - formtarget: 'formTarget', - frameborder: 'frameBorder', - headers: 'headers', - height: 'height', - hidden: 'hidden', - high: 'high', - href: 'href', - hreflang: 'hrefLang', - htmlfor: 'htmlFor', - httpequiv: 'httpEquiv', - 'http-equiv': 'httpEquiv', - icon: 'icon', - id: 'id', - innerhtml: 'innerHTML', - inputmode: 'inputMode', - integrity: 'integrity', - is: 'is', - itemid: 'itemID', - itemprop: 'itemProp', - itemref: 'itemRef', - itemscope: 'itemScope', - itemtype: 'itemType', - keyparams: 'keyParams', - keytype: 'keyType', - kind: 'kind', - label: 'label', - lang: 'lang', - list: 'list', - loop: 'loop', - low: 'low', - manifest: 'manifest', - marginwidth: 'marginWidth', - marginheight: 'marginHeight', - max: 'max', - maxlength: 'maxLength', - media: 'media', - mediagroup: 'mediaGroup', - method: 'method', - min: 'min', - minlength: 'minLength', - multiple: 'multiple', - muted: 'muted', - name: 'name', - nomodule: 'noModule', - nonce: 'nonce', - novalidate: 'noValidate', - open: 'open', - optimum: 'optimum', - pattern: 'pattern', - placeholder: 'placeholder', - playsinline: 'playsInline', - poster: 'poster', - preload: 'preload', - profile: 'profile', - radiogroup: 'radioGroup', - readonly: 'readOnly', - referrerpolicy: 'referrerPolicy', - rel: 'rel', - required: 'required', - reversed: 'reversed', - role: 'role', - rows: 'rows', - rowspan: 'rowSpan', - sandbox: 'sandbox', - scope: 'scope', - scoped: 'scoped', - scrolling: 'scrolling', - seamless: 'seamless', - selected: 'selected', - shape: 'shape', - size: 'size', - sizes: 'sizes', - span: 'span', - spellcheck: 'spellCheck', - src: 'src', - srcdoc: 'srcDoc', - srclang: 'srcLang', - srcset: 'srcSet', - start: 'start', - step: 'step', - style: 'style', - summary: 'summary', - tabindex: 'tabIndex', - target: 'target', - title: 'title', - type: 'type', - usemap: 'useMap', - value: 'value', - width: 'width', - wmode: 'wmode', - wrap: 'wrap', - - // SVG - about: 'about', - accentheight: 'accentHeight', - 'accent-height': 'accentHeight', - accumulate: 'accumulate', - additive: 'additive', - alignmentbaseline: 'alignmentBaseline', - 'alignment-baseline': 'alignmentBaseline', - allowreorder: 'allowReorder', - alphabetic: 'alphabetic', - amplitude: 'amplitude', - arabicform: 'arabicForm', - 'arabic-form': 'arabicForm', - ascent: 'ascent', - attributename: 'attributeName', - attributetype: 'attributeType', - autoreverse: 'autoReverse', - azimuth: 'azimuth', - basefrequency: 'baseFrequency', - baselineshift: 'baselineShift', - 'baseline-shift': 'baselineShift', - baseprofile: 'baseProfile', - bbox: 'bbox', - begin: 'begin', - bias: 'bias', - by: 'by', - calcmode: 'calcMode', - capheight: 'capHeight', - 'cap-height': 'capHeight', - clip: 'clip', - clippath: 'clipPath', - 'clip-path': 'clipPath', - clippathunits: 'clipPathUnits', - cliprule: 'clipRule', - 'clip-rule': 'clipRule', - color: 'color', - colorinterpolation: 'colorInterpolation', - 'color-interpolation': 'colorInterpolation', - colorinterpolationfilters: 'colorInterpolationFilters', - 'color-interpolation-filters': 'colorInterpolationFilters', - colorprofile: 'colorProfile', - 'color-profile': 'colorProfile', - colorrendering: 'colorRendering', - 'color-rendering': 'colorRendering', - contentscripttype: 'contentScriptType', - contentstyletype: 'contentStyleType', - cursor: 'cursor', - cx: 'cx', - cy: 'cy', - d: 'd', - datatype: 'datatype', - decelerate: 'decelerate', - descent: 'descent', - diffuseconstant: 'diffuseConstant', - direction: 'direction', - display: 'display', - divisor: 'divisor', - dominantbaseline: 'dominantBaseline', - 'dominant-baseline': 'dominantBaseline', - dur: 'dur', - dx: 'dx', - dy: 'dy', - edgemode: 'edgeMode', - elevation: 'elevation', - enablebackground: 'enableBackground', - 'enable-background': 'enableBackground', - end: 'end', - exponent: 'exponent', - externalresourcesrequired: 'externalResourcesRequired', - fill: 'fill', - fillopacity: 'fillOpacity', - 'fill-opacity': 'fillOpacity', - fillrule: 'fillRule', - 'fill-rule': 'fillRule', - filter: 'filter', - filterres: 'filterRes', - filterunits: 'filterUnits', - floodopacity: 'floodOpacity', - 'flood-opacity': 'floodOpacity', - floodcolor: 'floodColor', - 'flood-color': 'floodColor', - focusable: 'focusable', - fontfamily: 'fontFamily', - 'font-family': 'fontFamily', - fontsize: 'fontSize', - 'font-size': 'fontSize', - fontsizeadjust: 'fontSizeAdjust', - 'font-size-adjust': 'fontSizeAdjust', - fontstretch: 'fontStretch', - 'font-stretch': 'fontStretch', - fontstyle: 'fontStyle', - 'font-style': 'fontStyle', - fontvariant: 'fontVariant', - 'font-variant': 'fontVariant', - fontweight: 'fontWeight', - 'font-weight': 'fontWeight', - format: 'format', - from: 'from', - fx: 'fx', - fy: 'fy', - g1: 'g1', - g2: 'g2', - glyphname: 'glyphName', - 'glyph-name': 'glyphName', - glyphorientationhorizontal: 'glyphOrientationHorizontal', - 'glyph-orientation-horizontal': 'glyphOrientationHorizontal', - glyphorientationvertical: 'glyphOrientationVertical', - 'glyph-orientation-vertical': 'glyphOrientationVertical', - glyphref: 'glyphRef', - gradienttransform: 'gradientTransform', - gradientunits: 'gradientUnits', - hanging: 'hanging', - horizadvx: 'horizAdvX', - 'horiz-adv-x': 'horizAdvX', - horizoriginx: 'horizOriginX', - 'horiz-origin-x': 'horizOriginX', - ideographic: 'ideographic', - imagerendering: 'imageRendering', - 'image-rendering': 'imageRendering', - in2: 'in2', - in: 'in', - inlist: 'inlist', - intercept: 'intercept', - k1: 'k1', - k2: 'k2', - k3: 'k3', - k4: 'k4', - k: 'k', - kernelmatrix: 'kernelMatrix', - kernelunitlength: 'kernelUnitLength', - kerning: 'kerning', - keypoints: 'keyPoints', - keysplines: 'keySplines', - keytimes: 'keyTimes', - lengthadjust: 'lengthAdjust', - letterspacing: 'letterSpacing', - 'letter-spacing': 'letterSpacing', - lightingcolor: 'lightingColor', - 'lighting-color': 'lightingColor', - limitingconeangle: 'limitingConeAngle', - local: 'local', - markerend: 'markerEnd', - 'marker-end': 'markerEnd', - markerheight: 'markerHeight', - markermid: 'markerMid', - 'marker-mid': 'markerMid', - markerstart: 'markerStart', - 'marker-start': 'markerStart', - markerunits: 'markerUnits', - markerwidth: 'markerWidth', - mask: 'mask', - maskcontentunits: 'maskContentUnits', - maskunits: 'maskUnits', - mathematical: 'mathematical', - mode: 'mode', - numoctaves: 'numOctaves', - offset: 'offset', - opacity: 'opacity', - operator: 'operator', - order: 'order', - orient: 'orient', - orientation: 'orientation', - origin: 'origin', - overflow: 'overflow', - overlineposition: 'overlinePosition', - 'overline-position': 'overlinePosition', - overlinethickness: 'overlineThickness', - 'overline-thickness': 'overlineThickness', - paintorder: 'paintOrder', - 'paint-order': 'paintOrder', - panose1: 'panose1', - 'panose-1': 'panose1', - pathlength: 'pathLength', - patterncontentunits: 'patternContentUnits', - patterntransform: 'patternTransform', - patternunits: 'patternUnits', - pointerevents: 'pointerEvents', - 'pointer-events': 'pointerEvents', - points: 'points', - pointsatx: 'pointsAtX', - pointsaty: 'pointsAtY', - pointsatz: 'pointsAtZ', - prefix: 'prefix', - preservealpha: 'preserveAlpha', - preserveaspectratio: 'preserveAspectRatio', - primitiveunits: 'primitiveUnits', - property: 'property', - r: 'r', - radius: 'radius', - refx: 'refX', - refy: 'refY', - renderingintent: 'renderingIntent', - 'rendering-intent': 'renderingIntent', - repeatcount: 'repeatCount', - repeatdur: 'repeatDur', - requiredextensions: 'requiredExtensions', - requiredfeatures: 'requiredFeatures', - resource: 'resource', - restart: 'restart', - result: 'result', - results: 'results', - rotate: 'rotate', - rx: 'rx', - ry: 'ry', - scale: 'scale', - security: 'security', - seed: 'seed', - shaperendering: 'shapeRendering', - 'shape-rendering': 'shapeRendering', - slope: 'slope', - spacing: 'spacing', - specularconstant: 'specularConstant', - specularexponent: 'specularExponent', - speed: 'speed', - spreadmethod: 'spreadMethod', - startoffset: 'startOffset', - stddeviation: 'stdDeviation', - stemh: 'stemh', - stemv: 'stemv', - stitchtiles: 'stitchTiles', - stopcolor: 'stopColor', - 'stop-color': 'stopColor', - stopopacity: 'stopOpacity', - 'stop-opacity': 'stopOpacity', - strikethroughposition: 'strikethroughPosition', - 'strikethrough-position': 'strikethroughPosition', - strikethroughthickness: 'strikethroughThickness', - 'strikethrough-thickness': 'strikethroughThickness', - string: 'string', - stroke: 'stroke', - strokedasharray: 'strokeDasharray', - 'stroke-dasharray': 'strokeDasharray', - strokedashoffset: 'strokeDashoffset', - 'stroke-dashoffset': 'strokeDashoffset', - strokelinecap: 'strokeLinecap', - 'stroke-linecap': 'strokeLinecap', - strokelinejoin: 'strokeLinejoin', - 'stroke-linejoin': 'strokeLinejoin', - strokemiterlimit: 'strokeMiterlimit', - 'stroke-miterlimit': 'strokeMiterlimit', - strokewidth: 'strokeWidth', - 'stroke-width': 'strokeWidth', - strokeopacity: 'strokeOpacity', - 'stroke-opacity': 'strokeOpacity', - suppresscontenteditablewarning: 'suppressContentEditableWarning', - suppresshydrationwarning: 'suppressHydrationWarning', - surfacescale: 'surfaceScale', - systemlanguage: 'systemLanguage', - tablevalues: 'tableValues', - targetx: 'targetX', - targety: 'targetY', - textanchor: 'textAnchor', - 'text-anchor': 'textAnchor', - textdecoration: 'textDecoration', - 'text-decoration': 'textDecoration', - textlength: 'textLength', - textrendering: 'textRendering', - 'text-rendering': 'textRendering', - to: 'to', - transform: 'transform', - typeof: 'typeof', - u1: 'u1', - u2: 'u2', - underlineposition: 'underlinePosition', - 'underline-position': 'underlinePosition', - underlinethickness: 'underlineThickness', - 'underline-thickness': 'underlineThickness', - unicode: 'unicode', - unicodebidi: 'unicodeBidi', - 'unicode-bidi': 'unicodeBidi', - unicoderange: 'unicodeRange', - 'unicode-range': 'unicodeRange', - unitsperem: 'unitsPerEm', - 'units-per-em': 'unitsPerEm', - unselectable: 'unselectable', - valphabetic: 'vAlphabetic', - 'v-alphabetic': 'vAlphabetic', - values: 'values', - vectoreffect: 'vectorEffect', - 'vector-effect': 'vectorEffect', - version: 'version', - vertadvy: 'vertAdvY', - 'vert-adv-y': 'vertAdvY', - vertoriginx: 'vertOriginX', - 'vert-origin-x': 'vertOriginX', - vertoriginy: 'vertOriginY', - 'vert-origin-y': 'vertOriginY', - vhanging: 'vHanging', - 'v-hanging': 'vHanging', - videographic: 'vIdeographic', - 'v-ideographic': 'vIdeographic', - viewbox: 'viewBox', - viewtarget: 'viewTarget', - visibility: 'visibility', - vmathematical: 'vMathematical', - 'v-mathematical': 'vMathematical', - vocab: 'vocab', - widths: 'widths', - wordspacing: 'wordSpacing', - 'word-spacing': 'wordSpacing', - writingmode: 'writingMode', - 'writing-mode': 'writingMode', - x1: 'x1', - x2: 'x2', - x: 'x', - xchannelselector: 'xChannelSelector', - xheight: 'xHeight', - 'x-height': 'xHeight', - xlinkactuate: 'xlinkActuate', - 'xlink:actuate': 'xlinkActuate', - xlinkarcrole: 'xlinkArcrole', - 'xlink:arcrole': 'xlinkArcrole', - xlinkhref: 'xlinkHref', - 'xlink:href': 'xlinkHref', - xlinkrole: 'xlinkRole', - 'xlink:role': 'xlinkRole', - xlinkshow: 'xlinkShow', - 'xlink:show': 'xlinkShow', - xlinktitle: 'xlinkTitle', - 'xlink:title': 'xlinkTitle', - xlinktype: 'xlinkType', - 'xlink:type': 'xlinkType', - xmlbase: 'xmlBase', - 'xml:base': 'xmlBase', - xmllang: 'xmlLang', - 'xml:lang': 'xmlLang', - xmlns: 'xmlns', - 'xml:space': 'xmlSpace', - xmlnsxlink: 'xmlnsXlink', - 'xmlns:xlink': 'xmlnsXlink', - xmlspace: 'xmlSpace', - y1: 'y1', - y2: 'y2', - y: 'y', - ychannelselector: 'yChannelSelector', - z: 'z', - zoomandpan: 'zoomAndPan' -}; - -var validateProperty$1 = function () {}; - -{ - var warnedProperties$1 = {}; - var _hasOwnProperty = Object.prototype.hasOwnProperty; - var EVENT_NAME_REGEX = /^on./; - var INVALID_EVENT_NAME_REGEX = /^on[^A-Z]/; - var rARIA$1 = new RegExp('^(aria)-[' + ATTRIBUTE_NAME_CHAR + ']*$'); - var rARIACamel$1 = new RegExp('^(aria)[A-Z][' + ATTRIBUTE_NAME_CHAR + ']*$'); - - validateProperty$1 = function (tagName, name, value, canUseEventSystem) { - if (_hasOwnProperty.call(warnedProperties$1, name) && warnedProperties$1[name]) { - return true; - } - - var lowerCasedName = name.toLowerCase(); - if (lowerCasedName === 'onfocusin' || lowerCasedName === 'onfocusout') { - warning$1(false, 'React uses onFocus and onBlur instead of onFocusIn and onFocusOut. ' + 'All React events are normalized to bubble, so onFocusIn and onFocusOut ' + 'are not needed/supported by React.'); - warnedProperties$1[name] = true; - return true; - } - - // We can't rely on the event system being injected on the server. - if (canUseEventSystem) { - if (registrationNameModules.hasOwnProperty(name)) { - return true; - } - var registrationName = possibleRegistrationNames.hasOwnProperty(lowerCasedName) ? possibleRegistrationNames[lowerCasedName] : null; - if (registrationName != null) { - warning$1(false, 'Invalid event handler property `%s`. Did you mean `%s`?', name, registrationName); - warnedProperties$1[name] = true; - return true; - } - if (EVENT_NAME_REGEX.test(name)) { - warning$1(false, 'Unknown event handler property `%s`. It will be ignored.', name); - warnedProperties$1[name] = true; - return true; - } - } else if (EVENT_NAME_REGEX.test(name)) { - // If no event plugins have been injected, we are in a server environment. - // So we can't tell if the event name is correct for sure, but we can filter - // out known bad ones like `onclick`. We can't suggest a specific replacement though. - if (INVALID_EVENT_NAME_REGEX.test(name)) { - warning$1(false, 'Invalid event handler property `%s`. ' + 'React events use the camelCase naming convention, for example `onClick`.', name); - } - warnedProperties$1[name] = true; - return true; - } - - // Let the ARIA attribute hook validate ARIA attributes - if (rARIA$1.test(name) || rARIACamel$1.test(name)) { - return true; - } - - if (lowerCasedName === 'innerhtml') { - warning$1(false, 'Directly setting property `innerHTML` is not permitted. ' + 'For more information, lookup documentation on `dangerouslySetInnerHTML`.'); - warnedProperties$1[name] = true; - return true; - } - - if (lowerCasedName === 'aria') { - warning$1(false, 'The `aria` attribute is reserved for future use in React. ' + 'Pass individual `aria-` attributes instead.'); - warnedProperties$1[name] = true; - return true; - } - - if (lowerCasedName === 'is' && value !== null && value !== undefined && typeof value !== 'string') { - warning$1(false, 'Received a `%s` for a string attribute `is`. If this is expected, cast ' + 'the value to a string.', typeof value); - warnedProperties$1[name] = true; - return true; - } - - if (typeof value === 'number' && isNaN(value)) { - warning$1(false, 'Received NaN for the `%s` attribute. If this is expected, cast ' + 'the value to a string.', name); - warnedProperties$1[name] = true; - return true; - } - - var propertyInfo = getPropertyInfo(name); - var isReserved = propertyInfo !== null && propertyInfo.type === RESERVED; - - // Known attributes should match the casing specified in the property config. - if (possibleStandardNames.hasOwnProperty(lowerCasedName)) { - var standardName = possibleStandardNames[lowerCasedName]; - if (standardName !== name) { - warning$1(false, 'Invalid DOM property `%s`. Did you mean `%s`?', name, standardName); - warnedProperties$1[name] = true; - return true; - } - } else if (!isReserved && name !== lowerCasedName) { - // Unknown attributes should have lowercase casing since that's how they - // will be cased anyway with server rendering. - warning$1(false, 'React does not recognize the `%s` prop on a DOM element. If you ' + 'intentionally want it to appear in the DOM as a custom ' + 'attribute, spell it as lowercase `%s` instead. ' + 'If you accidentally passed it from a parent component, remove ' + 'it from the DOM element.', name, lowerCasedName); - warnedProperties$1[name] = true; - return true; - } - - if (typeof value === 'boolean' && shouldRemoveAttributeWithWarning(name, value, propertyInfo, false)) { - if (value) { - warning$1(false, 'Received `%s` for a non-boolean attribute `%s`.\n\n' + 'If you want to write it to the DOM, pass a string instead: ' + '%s="%s" or %s={value.toString()}.', value, name, name, value, name); - } else { - warning$1(false, 'Received `%s` for a non-boolean attribute `%s`.\n\n' + 'If you want to write it to the DOM, pass a string instead: ' + '%s="%s" or %s={value.toString()}.\n\n' + 'If you used to conditionally omit it with %s={condition && value}, ' + 'pass %s={condition ? value : undefined} instead.', value, name, name, value, name, name, name); - } - warnedProperties$1[name] = true; - return true; - } - - // Now that we've validated casing, do not validate - // data types for reserved props - if (isReserved) { - return true; - } - - // Warn when a known attribute is a bad type - if (shouldRemoveAttributeWithWarning(name, value, propertyInfo, false)) { - warnedProperties$1[name] = true; - return false; - } - - // Warn when passing the strings 'false' or 'true' into a boolean prop - if ((value === 'false' || value === 'true') && propertyInfo !== null && propertyInfo.type === BOOLEAN) { - warning$1(false, 'Received the string `%s` for the boolean attribute `%s`. ' + '%s ' + 'Did you mean %s={%s}?', value, name, value === 'false' ? 'The browser will interpret it as a truthy value.' : 'Although this works, it will not work as expected if you pass the string "false".', name, value); - warnedProperties$1[name] = true; - return true; - } - - return true; - }; -} - -var warnUnknownProperties = function (type, props, canUseEventSystem) { - var unknownProps = []; - for (var key in props) { - var isValid = validateProperty$1(type, key, props[key], canUseEventSystem); - if (!isValid) { - unknownProps.push(key); - } - } - - var unknownPropString = unknownProps.map(function (prop) { - return '`' + prop + '`'; - }).join(', '); - if (unknownProps.length === 1) { - warning$1(false, 'Invalid value for prop %s on <%s> tag. Either remove it from the element, ' + 'or pass a string or number value to keep it in the DOM. ' + 'For details, see https://fb.me/react-attribute-behavior', unknownPropString, type); - } else if (unknownProps.length > 1) { - warning$1(false, 'Invalid values for props %s on <%s> tag. Either remove them from the element, ' + 'or pass a string or number value to keep them in the DOM. ' + 'For details, see https://fb.me/react-attribute-behavior', unknownPropString, type); - } -}; - -function validateProperties$2(type, props, canUseEventSystem) { - if (isCustomComponent(type, props)) { - return; - } - warnUnknownProperties(type, props, canUseEventSystem); -} - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -// Based on reading the React.Children implementation. TODO: type this somewhere? - -var toArray = React.Children.toArray; - -// This is only used in DEV. -// Each entry is `this.stack` from a currently executing renderer instance. -// (There may be more than one because ReactDOMServer is reentrant). -// Each stack is an array of frames which may contain nested stacks of elements. -var currentDebugStacks = []; - -var ReactCurrentOwner = ReactSharedInternals.ReactCurrentOwner; -var ReactDebugCurrentFrame = void 0; -var prevGetCurrentStackImpl = null; -var getCurrentServerStackImpl = function () { - return ''; -}; -var describeStackFrame = function (element) { - return ''; -}; - -var validatePropertiesInDevelopment = function (type, props) {}; -var pushCurrentDebugStack = function (stack) {}; -var pushElementToDebugStack = function (element) {}; -var popCurrentDebugStack = function () {}; -var hasWarnedAboutUsingContextAsConsumer = false; - -{ - ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame; - - validatePropertiesInDevelopment = function (type, props) { - validateProperties(type, props); - validateProperties$1(type, props); - validateProperties$2(type, props, /* canUseEventSystem */false); - }; - - describeStackFrame = function (element) { - var source = element._source; - var type = element.type; - var name = getComponentName(type); - var ownerName = null; - return describeComponentFrame(name, source, ownerName); - }; - - pushCurrentDebugStack = function (stack) { - currentDebugStacks.push(stack); - - if (currentDebugStacks.length === 1) { - // We are entering a server renderer. - // Remember the previous (e.g. client) global stack implementation. - prevGetCurrentStackImpl = ReactDebugCurrentFrame.getCurrentStack; - ReactDebugCurrentFrame.getCurrentStack = getCurrentServerStackImpl; - } - }; - - pushElementToDebugStack = function (element) { - // For the innermost executing ReactDOMServer call, - var stack = currentDebugStacks[currentDebugStacks.length - 1]; - // Take the innermost executing frame (e.g. ), - var frame = stack[stack.length - 1]; - // and record that it has one more element associated with it. - frame.debugElementStack.push(element); - // We only need this because we tail-optimize single-element - // children and directly handle them in an inner loop instead of - // creating separate frames for them. - }; - - popCurrentDebugStack = function () { - currentDebugStacks.pop(); - - if (currentDebugStacks.length === 0) { - // We are exiting the server renderer. - // Restore the previous (e.g. client) global stack implementation. - ReactDebugCurrentFrame.getCurrentStack = prevGetCurrentStackImpl; - prevGetCurrentStackImpl = null; - } - }; - - getCurrentServerStackImpl = function () { - if (currentDebugStacks.length === 0) { - // Nothing is currently rendering. - return ''; - } - // ReactDOMServer is reentrant so there may be multiple calls at the same time. - // Take the frames from the innermost call which is the last in the array. - var frames = currentDebugStacks[currentDebugStacks.length - 1]; - var stack = ''; - // Go through every frame in the stack from the innermost one. - for (var i = frames.length - 1; i >= 0; i--) { - var frame = frames[i]; - // Every frame might have more than one debug element stack entry associated with it. - // This is because single-child nesting doesn't create materialized frames. - // Instead it would push them through `pushElementToDebugStack()`. - var _debugElementStack = frame.debugElementStack; - for (var ii = _debugElementStack.length - 1; ii >= 0; ii--) { - stack += describeStackFrame(_debugElementStack[ii]); - } - } - return stack; - }; -} - -var didWarnDefaultInputValue = false; -var didWarnDefaultChecked = false; -var didWarnDefaultSelectValue = false; -var didWarnDefaultTextareaValue = false; -var didWarnInvalidOptionChildren = false; -var didWarnAboutNoopUpdateForComponent = {}; -var didWarnAboutBadClass = {}; -var didWarnAboutDeprecatedWillMount = {}; -var didWarnAboutUndefinedDerivedState = {}; -var didWarnAboutUninitializedState = {}; -var valuePropNames = ['value', 'defaultValue']; -var newlineEatingTags = { - listing: true, - pre: true, - textarea: true -}; - -// We accept any tag to be rendered but since this gets injected into arbitrary -// HTML, we want to make sure that it's a safe tag. -// http://www.w3.org/TR/REC-xml/#NT-Name -var VALID_TAG_REGEX = /^[a-zA-Z][a-zA-Z:_\.\-\d]*$/; // Simplified subset -var validatedTagCache = {}; -function validateDangerousTag(tag) { - if (!validatedTagCache.hasOwnProperty(tag)) { - !VALID_TAG_REGEX.test(tag) ? invariant(false, 'Invalid tag: %s', tag) : void 0; - validatedTagCache[tag] = true; - } -} - -var styleNameCache = {}; -var processStyleName = function (styleName) { - if (styleNameCache.hasOwnProperty(styleName)) { - return styleNameCache[styleName]; - } - var result = hyphenateStyleName(styleName); - styleNameCache[styleName] = result; - return result; -}; - -function createMarkupForStyles(styles) { - var serialized = ''; - var delimiter = ''; - for (var styleName in styles) { - if (!styles.hasOwnProperty(styleName)) { - continue; - } - var isCustomProperty = styleName.indexOf('--') === 0; - var styleValue = styles[styleName]; - { - if (!isCustomProperty) { - warnValidStyle$1(styleName, styleValue); - } - } - if (styleValue != null) { - serialized += delimiter + processStyleName(styleName) + ':'; - serialized += dangerousStyleValue(styleName, styleValue, isCustomProperty); - - delimiter = ';'; - } - } - return serialized || null; -} - -function warnNoop(publicInstance, callerName) { - { - var _constructor = publicInstance.constructor; - var componentName = _constructor && getComponentName(_constructor) || 'ReactClass'; - var warningKey = componentName + '.' + callerName; - if (didWarnAboutNoopUpdateForComponent[warningKey]) { - return; - } - - warningWithoutStack$1(false, '%s(...): Can only update a mounting component. ' + 'This usually means you called %s() outside componentWillMount() on the server. ' + 'This is a no-op.\n\nPlease check the code for the %s component.', callerName, callerName, componentName); - didWarnAboutNoopUpdateForComponent[warningKey] = true; - } -} - -function shouldConstruct(Component) { - return Component.prototype && Component.prototype.isReactComponent; -} - -function getNonChildrenInnerMarkup(props) { - var innerHTML = props.dangerouslySetInnerHTML; - if (innerHTML != null) { - if (innerHTML.__html != null) { - return innerHTML.__html; - } - } else { - var content = props.children; - if (typeof content === 'string' || typeof content === 'number') { - return escapeTextForBrowser(content); - } - } - return null; -} - -function flattenTopLevelChildren(children) { - if (!React.isValidElement(children)) { - return toArray(children); - } - var element = children; - if (element.type !== REACT_FRAGMENT_TYPE) { - return [element]; - } - var fragmentChildren = element.props.children; - if (!React.isValidElement(fragmentChildren)) { - return toArray(fragmentChildren); - } - var fragmentChildElement = fragmentChildren; - return [fragmentChildElement]; -} - -function flattenOptionChildren(children) { - if (children === undefined || children === null) { - return children; - } - var content = ''; - // Flatten children and warn if they aren't strings or numbers; - // invalid types are ignored. - React.Children.forEach(children, function (child) { - if (child == null) { - return; - } - content += child; - { - if (!didWarnInvalidOptionChildren && typeof child !== 'string' && typeof child !== 'number') { - didWarnInvalidOptionChildren = true; - warning$1(false, 'Only strings and numbers are supported as