From 1063178e8d3b10f729b4046c0dbc964386e80746 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Felix=20Sp=C3=B6ttel?=
<1682504+fspoettel@users.noreply.github.com>
Date: Fri, 27 Jan 2023 18:13:23 +0100
Subject: [PATCH] feat: Switch tooling to `vite` (#67)
closes https://github.com/bellingcat/ukraine-timemap/issues/66
---
.eslintrc.js | 31 +
.prettierignore | 4 -
.prettierrc | 0
config.js | 5 +-
config/env.js | 125 -
config/getHttpsConfig.js | 66 -
config/jest/cssTransform.js | 14 -
config/jest/fileTransform.js | 40 -
config/jest/setEnvVars.js | 2 -
config/modules.js | 134 -
config/paths.js | 73 -
config/pnpTs.js | 35 -
config/webpack.config.js | 748 -
config/webpackDevServer.config.js | 130 -
example.config.js | 4 +-
index.html | 5 +-
package-lock.json | 47241 +---------------
package.json | 175 +-
scripts/build.js | 212 -
scripts/start.js | 166 -
scripts/test.js | 53 -
src/common/utilities.js | 21 +-
src/components/{App.js => App.jsx} | 4 +-
.../{InfoPopup.js => InfoPopup.jsx} | 1 -
src/components/{Layout.js => Layout.jsx} | 6 +-
.../{Notification.js => Notification.jsx} | 4 +-
src/components/{Portal.js => Portal.jsx} | 4 +-
.../{TemplateCover.js => TemplateCover.jsx} | 6 +-
src/components/{Toolbar.js => Toolbar.jsx} | 9 +-
.../atoms/{Checkbox.js => Checkbox.jsx} | 1 -
.../atoms/{CoeventIcon.js => CoeventIcon.jsx} | 10 +-
.../{ColoredMarkers.js => ColoredMarkers.jsx} | 1 -
.../atoms/{Content.js => Content.jsx} | 1 -
.../atoms/{Controls.js => Controls.jsx} | 2 -
.../atoms/{CoverIcon.js => CoverIcon.jsx} | 2 -
.../atoms/{InfoIcon.js => InfoIcon.jsx} | 2 -
.../atoms/{Loading.js => Loading.jsx} | 1 -
src/components/atoms/{Md.js => Md.jsx} | 6 +-
src/components/atoms/{Media.js => Media.jsx} | 6 +-
.../atoms/{NoSource.js => NoSource.jsx} | 2 -
src/components/atoms/{Popup.js => Popup.jsx} | 3 +-
.../atoms/{RefreshIcon.js => RefreshIcon.jsx} | 6 +-
.../atoms/{RouteIcon.js => RouteIcon.jsx} | 2 -
.../atoms/{SitesIcon.js => SitesIcon.jsx} | 2 -
.../atoms/{Spinner.js => Spinner.jsx} | 2 -
.../atoms/{StaticPage.js => StaticPage.jsx} | 2 -
.../{BottomActions.js => BottomActions.jsx} | 2 -
src/components/controls/{Card.js => Card.jsx} | 2 +-
.../controls/{CardStack.js => CardStack.jsx} | 10 +-
...esListPanel.js => CategoriesListPanel.jsx} | 3 +-
.../{DownloadButton.js => DownloadButton.jsx} | 11 +-
.../{DownloadPanel.js => DownloadPanel.jsx} | 1 -
...FilterListPanel.js => FilterListPanel.jsx} | 5 +-
...llScreenToggle.js => FullScreenToggle.jsx} | 4 +-
...ativeControls.js => NarrativeControls.jsx} | 1 -
.../controls/{Search.js => Search.jsx} | 4 +-
...ShapesListPanel.js => ShapesListPanel.jsx} | 3 +-
.../controls/atoms/{Button.js => Button.jsx} | 1 -
.../controls/atoms/{Caret.js => Caret.jsx} | 2 -
.../atoms/{CustomField.js => CustomField.jsx} | 3 +-
.../controls/atoms/{Media.js => Media.jsx} | 2 +-
...NarrativeAdjust.js => NarrativeAdjust.jsx} | 2 -
.../{NarrativeCard.js => NarrativeCard.jsx} | 1 -
.../{NarrativeClose.js => NarrativeClose.jsx} | 2 -
.../atoms/{PanelTree.js => PanelTree.jsx} | 1 -
src/components/controls/atoms/SearchRow.jsx | 2 -
.../{TelegramEmbed.js => TelegramEmbed.jsx} | 2 +-
.../controls/atoms/{Text.js => Text.jsx} | 2 +-
.../controls/atoms/{Time.js => Time.jsx} | 2 -
.../{ToolbarButton.js => ToolbarButton.jsx} | 0
src/components/space/{Space.js => Space.jsx} | 1 -
.../space/carto/{Map.js => Map.jsx} | 22 +-
.../carto/atoms/{Clusters.js => Clusters.jsx} | 6 +-
.../atoms/{DefsMarkers.js => DefsMarkers.jsx} | 2 -
.../carto/atoms/{Events.js => Events.jsx} | 1 -
.../atoms/{Narratives.js => Narratives.jsx} | 1 -
.../carto/atoms/{Regions.js => Regions.jsx} | 1 -
...ayToggle.js => SatelliteOverlayToggle.jsx} | 2 +-
.../{SelectedEvents.js => SelectedEvents.jsx} | 4 +-
.../space/carto/atoms/{Sites.js => Sites.jsx} | 2 -
...pec.js => SatelliteOverlayToggle.spec.jsx} | 28 +-
src/components/time/{Axis.js => Axis.jsx} | 8 +-
.../time/{Categories.js => Categories.jsx} | 6 +-
.../time/{Timeline.js => Timeline.jsx} | 14 +-
.../time/atoms/{Clip.js => Clip.jsx} | 2 -
.../atoms/{DatetimeBar.js => DatetimeBar.jsx} | 2 -
.../atoms/{DatetimeDot.js => DatetimeDot.jsx} | 2 -
...tetimePentagon.js => DatetimePentagon.jsx} | 2 -
.../{DatetimeSquare.js => DatetimeSquare.jsx} | 2 -
.../{DatetimeStar.js => DatetimeStar.jsx} | 2 -
...tetimeTriangle.js => DatetimeTriangle.jsx} | 2 -
.../time/atoms/{Events.js => Events.jsx} | 1 -
.../time/atoms/{Handles.js => Handles.jsx} | 2 -
.../time/atoms/{Header.js => Header.jsx} | 1 -
.../time/atoms/{Labels.js => Labels.jsx} | 2 -
.../time/atoms/{Markers.js => Markers.jsx} | 1 -
.../time/atoms/{Project.js => Project.jsx} | 2 -
.../{ZoomControls.js => ZoomControls.jsx} | 2 -
src/index.jsx | 1 -
src/reducers/__tests__/index.spec.js | 2 +-
src/reducers/__tests__/ui.spec.js | 13 +-
src/reducers/app.js | 2 +-
src/reducers/domain.js | 4 +-
src/reducers/features.js | 2 +-
src/reducers/index.js | 10 +-
src/reducers/ui.js | 2 +-
src/reducers/validate/validators.js | 10 +-
src/scss/_variables.scss | 2 +-
src/scss/_video.scss | 45 -
src/scss/mediaplayer.scss | 2 +-
src/scss/video.scss | 46 +
src/setupTests.js | 11 -
src/store/initial.js | 5 +-
src/test/{App.test.js => App.test.jsx} | 7 +-
test/__mocks__/fileMock.js | 1 +
test/__mocks__/styleMock.js | 11 +
test/server_process.js | 65 -
test/setup.js | 4 +
vite.config.js | 24 +
119 files changed, 3262 insertions(+), 46567 deletions(-)
create mode 100644 .eslintrc.js
delete mode 100644 .prettierignore
create mode 100644 .prettierrc
delete mode 100644 config/env.js
delete mode 100644 config/getHttpsConfig.js
delete mode 100644 config/jest/cssTransform.js
delete mode 100644 config/jest/fileTransform.js
delete mode 100644 config/jest/setEnvVars.js
delete mode 100644 config/modules.js
delete mode 100644 config/paths.js
delete mode 100644 config/pnpTs.js
delete mode 100644 config/webpack.config.js
delete mode 100644 config/webpackDevServer.config.js
delete mode 100644 scripts/build.js
delete mode 100644 scripts/start.js
delete mode 100644 scripts/test.js
rename src/components/{App.js => App.jsx} (65%)
rename src/components/{InfoPopup.js => InfoPopup.jsx} (92%)
rename src/components/{Layout.js => Layout.jsx} (98%)
rename src/components/{Notification.js => Notification.jsx} (94%)
rename src/components/{Portal.js => Portal.jsx} (74%)
rename src/components/{TemplateCover.js => TemplateCover.jsx} (98%)
rename src/components/{Toolbar.js => Toolbar.jsx} (98%)
rename src/components/atoms/{Checkbox.js => Checkbox.jsx} (97%)
rename src/components/atoms/{CoeventIcon.js => CoeventIcon.jsx} (84%)
rename src/components/atoms/{ColoredMarkers.js => ColoredMarkers.jsx} (98%)
rename src/components/atoms/{Content.js => Content.jsx} (99%)
rename src/components/atoms/{Controls.js => Controls.jsx} (96%)
rename src/components/atoms/{CoverIcon.js => CoverIcon.jsx} (92%)
rename src/components/atoms/{InfoIcon.js => InfoIcon.jsx} (92%)
rename src/components/atoms/{Loading.js => Loading.jsx} (95%)
rename src/components/atoms/{Md.js => Md.jsx} (90%)
rename src/components/atoms/{Media.js => Media.jsx} (97%)
rename src/components/atoms/{NoSource.js => NoSource.jsx} (93%)
rename src/components/atoms/{Popup.js => Popup.jsx} (93%)
rename src/components/atoms/{RefreshIcon.js => RefreshIcon.jsx} (86%)
rename src/components/atoms/{RouteIcon.js => RouteIcon.jsx} (94%)
rename src/components/atoms/{SitesIcon.js => SitesIcon.jsx} (92%)
rename src/components/atoms/{Spinner.js => Spinner.jsx} (89%)
rename src/components/atoms/{StaticPage.js => StaticPage.jsx} (85%)
rename src/components/controls/{BottomActions.js => BottomActions.jsx} (97%)
rename src/components/controls/{Card.js => Card.jsx} (99%)
rename src/components/controls/{CardStack.js => CardStack.jsx} (95%)
rename src/components/controls/{CategoriesListPanel.js => CategoriesListPanel.jsx} (91%)
rename src/components/controls/{DownloadButton.js => DownloadButton.jsx} (91%)
rename src/components/controls/{DownloadPanel.js => DownloadPanel.jsx} (95%)
rename src/components/controls/{FilterListPanel.js => FilterListPanel.jsx} (94%)
rename src/components/controls/{FullScreenToggle.js => FullScreenToggle.jsx} (93%)
rename src/components/controls/{NarrativeControls.js => NarrativeControls.jsx} (96%)
rename src/components/controls/{Search.js => Search.jsx} (97%)
rename src/components/controls/{ShapesListPanel.js => ShapesListPanel.jsx} (92%)
rename src/components/controls/atoms/{Button.js => Button.jsx} (98%)
rename src/components/controls/atoms/{Caret.js => Caret.jsx} (90%)
rename src/components/controls/atoms/{CustomField.js => CustomField.jsx} (83%)
rename src/components/controls/atoms/{Media.js => Media.jsx} (98%)
rename src/components/controls/atoms/{NarrativeAdjust.js => NarrativeAdjust.jsx} (92%)
rename src/components/controls/atoms/{NarrativeCard.js => NarrativeCard.jsx} (97%)
rename src/components/controls/atoms/{NarrativeClose.js => NarrativeClose.jsx} (91%)
rename src/components/controls/atoms/{PanelTree.js => PanelTree.jsx} (96%)
rename src/components/controls/atoms/{TelegramEmbed.js => TelegramEmbed.jsx} (98%)
rename src/components/controls/atoms/{Text.js => Text.jsx} (96%)
rename src/components/controls/atoms/{Time.js => Time.jsx} (96%)
rename src/components/controls/atoms/{ToolbarButton.js => ToolbarButton.jsx} (100%)
rename src/components/space/{Space.js => Space.jsx} (90%)
rename src/components/space/carto/{Map.js => Map.jsx} (97%)
rename src/components/space/carto/atoms/{Clusters.js => Clusters.jsx} (96%)
rename src/components/space/carto/atoms/{DefsMarkers.js => DefsMarkers.jsx} (95%)
rename src/components/space/carto/atoms/{Events.js => Events.jsx} (99%)
rename src/components/space/carto/atoms/{Narratives.js => Narratives.jsx} (99%)
rename src/components/space/carto/atoms/{Regions.js => Regions.jsx} (97%)
rename src/components/space/carto/atoms/{SatelliteOverlayToggle.js => SatelliteOverlayToggle.jsx} (96%)
rename src/components/space/carto/atoms/{SelectedEvents.js => SelectedEvents.jsx} (93%)
rename src/components/space/carto/atoms/{Sites.js => Sites.jsx} (95%)
rename src/components/space/carto/atoms/__tests__/{SatelliteOverlayToggle.spec.js => SatelliteOverlayToggle.spec.jsx} (61%)
rename src/components/time/{Axis.js => Axis.jsx} (92%)
rename src/components/time/{Categories.js => Categories.jsx} (94%)
rename src/components/time/{Timeline.js => Timeline.jsx} (98%)
rename src/components/time/atoms/{Clip.js => Clip.jsx} (90%)
rename src/components/time/atoms/{DatetimeBar.js => DatetimeBar.jsx} (96%)
rename src/components/time/atoms/{DatetimeDot.js => DatetimeDot.jsx} (90%)
rename src/components/time/atoms/{DatetimePentagon.js => DatetimePentagon.jsx} (93%)
rename src/components/time/atoms/{DatetimeSquare.js => DatetimeSquare.jsx} (92%)
rename src/components/time/atoms/{DatetimeStar.js => DatetimeStar.jsx} (93%)
rename src/components/time/atoms/{DatetimeTriangle.js => DatetimeTriangle.jsx} (93%)
rename src/components/time/atoms/{Events.js => Events.jsx} (99%)
rename src/components/time/atoms/{Handles.js => Handles.jsx} (94%)
rename src/components/time/atoms/{Header.js => Header.jsx} (95%)
rename src/components/time/atoms/{Labels.js => Labels.jsx} (96%)
rename src/components/time/atoms/{Markers.js => Markers.jsx} (99%)
rename src/components/time/atoms/{Project.js => Project.jsx} (94%)
rename src/components/time/atoms/{ZoomControls.js => ZoomControls.jsx} (97%)
delete mode 100644 src/scss/_video.scss
delete mode 100644 src/setupTests.js
rename src/test/{App.test.js => App.test.jsx} (63%)
create mode 100644 test/__mocks__/fileMock.js
create mode 100644 test/__mocks__/styleMock.js
delete mode 100644 test/server_process.js
create mode 100644 test/setup.js
create mode 100644 vite.config.js
diff --git a/.eslintrc.js b/.eslintrc.js
new file mode 100644
index 0000000..422d676
--- /dev/null
+++ b/.eslintrc.js
@@ -0,0 +1,31 @@
+module.exports = {
+ root: true,
+ plugins: [],
+
+ parserOptions: {
+ sourceType: "module",
+ ecmaFeatures: {
+ jsx: true,
+ },
+ },
+ settings: {
+ react: {
+ version: "detect",
+ },
+ },
+ extends: [
+ "eslint:recommended",
+ "plugin:react/recommended",
+ "plugin:react/jsx-runtime",
+ "plugin:react-hooks/recommended",
+ "prettier",
+ ],
+ env: {
+ browser: true,
+ es2022: true,
+ jest: true,
+ },
+ rules: {
+ "react/prop-types": 0,
+ }
+};
diff --git a/.prettierignore b/.prettierignore
deleted file mode 100644
index 51d10f8..0000000
--- a/.prettierignore
+++ /dev/null
@@ -1,4 +0,0 @@
-# Ignore Create React App-related scaffolding
-config/
-scripts/
-test/server_process.js
\ No newline at end of file
diff --git a/.prettierrc b/.prettierrc
new file mode 100644
index 0000000..e69de29
diff --git a/config.js b/config.js
index a35485a..a8ffe76 100755
--- a/config.js
+++ b/config.js
@@ -1,5 +1,6 @@
const one_day = 1440;
-module.exports = {
+
+const config = {
title: "ukraine",
display_title: "Civilian Harm\nin Ukraine",
SERVER_ROOT: "https://ukraine.bellingcat.com/ukraine-server",
@@ -166,3 +167,5 @@ module.exports = {
},
},
};
+
+export default config;
diff --git a/config/env.js b/config/env.js
deleted file mode 100644
index 37eb3bf..0000000
--- a/config/env.js
+++ /dev/null
@@ -1,125 +0,0 @@
-"use strict";
-
-const fs = require("fs");
-const path = require("path");
-const paths = require("./paths");
-
-// Make sure that including paths.js after env.js will read .env variables.
-delete require.cache[require.resolve("./paths")];
-
-// START - injecting env variables from config.js
-// This section is responsible for require-ing the provided
-// command-line argument configuration file and serializing it.
-// It will later be available inside our app under process.env,
-// through webpack.definePlugin
-const CONFIG = process.env.CONFIG || "config.js";
-const envConfig = require("../" + CONFIG);
-
-const userConfig = {};
-for (const k in envConfig) {
- userConfig[k] = JSON.stringify(envConfig[k]);
-}
-// END - injecting env variables from config.js
-
-const NODE_ENV = process.env.NODE_ENV;
-if (!NODE_ENV) {
- throw new Error(
- "The NODE_ENV environment variable is required but was not specified."
- );
-}
-
-// https://github.com/bkeepers/dotenv#what-other-env-files-can-i-use
-const dotenvFiles = [
- `${paths.dotenv}.${NODE_ENV}.local`,
- // Don't include `.env.local` for `test` environment
- // since normally you expect tests to produce the same
- // results for everyone
- NODE_ENV !== "test" && `${paths.dotenv}.local`,
- `${paths.dotenv}.${NODE_ENV}`,
- paths.dotenv,
-].filter(Boolean);
-
-// Load environment variables from .env* files. Suppress warnings using silent
-// if this file is missing. dotenv will never modify any environment variables
-// that have already been set. Variable expansion is supported in .env files.
-// https://github.com/motdotla/dotenv
-// https://github.com/motdotla/dotenv-expand
-dotenvFiles.forEach((dotenvFile) => {
- if (fs.existsSync(dotenvFile)) {
- require("dotenv-expand")(
- require("dotenv").config({
- path: dotenvFile,
- })
- );
- }
-});
-
-// We support resolving modules according to `NODE_PATH`.
-// This lets you use absolute paths in imports inside large monorepos:
-// https://github.com/facebook/create-react-app/issues/253.
-// It works similar to `NODE_PATH` in Node itself:
-// https://nodejs.org/api/modules.html#modules_loading_from_the_global_folders
-// Note that unlike in Node, only *relative* paths from `NODE_PATH` are honored.
-// Otherwise, we risk importing Node.js core modules into an app instead of webpack shims.
-// https://github.com/facebook/create-react-app/issues/1023#issuecomment-265344421
-// We also resolve them to make sure all tools using them work consistently.
-const appDirectory = fs.realpathSync(process.cwd());
-process.env.NODE_PATH = (process.env.NODE_PATH || "")
- .split(path.delimiter)
- .filter((folder) => folder && !path.isAbsolute(folder))
- .map((folder) => path.resolve(appDirectory, folder))
- .join(path.delimiter);
-
-// Grab NODE_ENV and REACT_APP_* environment variables and prepare them to be
-// injected into the application via DefinePlugin in webpack configuration.
-const REACT_APP = /^REACT_APP_/i;
-
-function getClientEnvironment(publicUrl) {
- const raw = Object.keys(process.env)
- .filter((key) => REACT_APP.test(key))
- .reduce(
- (env, key) => {
- env[key] = process.env[key];
- return env;
- },
- {
- // Useful for determining whether we’re running in production mode.
- // Most importantly, it switches React into the correct mode.
- NODE_ENV: process.env.NODE_ENV || "development",
- // Useful for resolving the correct path to static assets in `public`.
- // For example,
.
- // This should only be used as an escape hatch. Normally you would put
- // images into the `src` and `import` them in code to get their paths.
- PUBLIC_URL: publicUrl,
- // We support configuring the sockjs pathname during development.
- // These settings let a developer run multiple simultaneous projects.
- // They are used as the connection `hostname`, `pathname` and `port`
- // in webpackHotDevClient. They are used as the `sockHost`, `sockPath`
- // and `sockPort` options in webpack-dev-server.
- WDS_SOCKET_HOST: process.env.WDS_SOCKET_HOST,
- WDS_SOCKET_PATH: process.env.WDS_SOCKET_PATH,
- WDS_SOCKET_PORT: process.env.WDS_SOCKET_PORT,
- // Whether or not react-refresh is enabled.
- // react-refresh is not 100% stable at this time,
- // which is why it's disabled by default.
- // It is defined here so it is available in the webpackHotDevClient.
- FAST_REFRESH: process.env.FAST_REFRESH !== "false",
- }
- );
- // Stringify all values so we can feed into webpack DefinePlugin
- const stringified = {
- "process.env": Object.keys(raw).reduce(
- (env, key) => {
- env[key] = JSON.stringify(raw[key]);
- return env;
- },
- {
- ...userConfig,
- }
- ),
- };
-
- return { raw, stringified };
-}
-
-module.exports = getClientEnvironment;
diff --git a/config/getHttpsConfig.js b/config/getHttpsConfig.js
deleted file mode 100644
index 013d493..0000000
--- a/config/getHttpsConfig.js
+++ /dev/null
@@ -1,66 +0,0 @@
-'use strict';
-
-const fs = require('fs');
-const path = require('path');
-const crypto = require('crypto');
-const chalk = require('react-dev-utils/chalk');
-const paths = require('./paths');
-
-// Ensure the certificate and key provided are valid and if not
-// throw an easy to debug error
-function validateKeyAndCerts({ cert, key, keyFile, crtFile }) {
- let encrypted;
- try {
- // publicEncrypt will throw an error with an invalid cert
- encrypted = crypto.publicEncrypt(cert, Buffer.from('test'));
- } catch (err) {
- throw new Error(
- `The certificate "${chalk.yellow(crtFile)}" is invalid.\n${err.message}`
- );
- }
-
- try {
- // privateDecrypt will throw an error with an invalid key
- crypto.privateDecrypt(key, encrypted);
- } catch (err) {
- throw new Error(
- `The certificate key "${chalk.yellow(keyFile)}" is invalid.\n${
- err.message
- }`
- );
- }
-}
-
-// Read file and throw an error if it doesn't exist
-function readEnvFile(file, type) {
- if (!fs.existsSync(file)) {
- throw new Error(
- `You specified ${chalk.cyan(
- type
- )} in your env, but the file "${chalk.yellow(file)}" can't be found.`
- );
- }
- return fs.readFileSync(file);
-}
-
-// Get the https config
-// Return cert files if provided in env, otherwise just true or false
-function getHttpsConfig() {
- const { SSL_CRT_FILE, SSL_KEY_FILE, HTTPS } = process.env;
- const isHttps = HTTPS === 'true';
-
- if (isHttps && SSL_CRT_FILE && SSL_KEY_FILE) {
- const crtFile = path.resolve(paths.appPath, SSL_CRT_FILE);
- const keyFile = path.resolve(paths.appPath, SSL_KEY_FILE);
- const config = {
- cert: readEnvFile(crtFile, 'SSL_CRT_FILE'),
- key: readEnvFile(keyFile, 'SSL_KEY_FILE'),
- };
-
- validateKeyAndCerts({ ...config, keyFile, crtFile });
- return config;
- }
- return isHttps;
-}
-
-module.exports = getHttpsConfig;
diff --git a/config/jest/cssTransform.js b/config/jest/cssTransform.js
deleted file mode 100644
index 606cc27..0000000
--- a/config/jest/cssTransform.js
+++ /dev/null
@@ -1,14 +0,0 @@
-"use strict";
-
-// This is a custom Jest transformer turning style imports into empty objects.
-// http://facebook.github.io/jest/docs/en/webpack.html
-
-module.exports = {
- process() {
- return "module.exports = {};";
- },
- getCacheKey() {
- // The output is always the same.
- return "cssTransform";
- },
-};
diff --git a/config/jest/fileTransform.js b/config/jest/fileTransform.js
deleted file mode 100644
index ca3edd0..0000000
--- a/config/jest/fileTransform.js
+++ /dev/null
@@ -1,40 +0,0 @@
-"use strict";
-
-const path = require("path");
-const camelcase = require("camelcase");
-
-// This is a custom Jest transformer turning file imports into filenames.
-// http://facebook.github.io/jest/docs/en/webpack.html
-
-module.exports = {
- process(src, filename) {
- const assetFilename = JSON.stringify(path.basename(filename));
-
- if (filename.match(/\.svg$/)) {
- // Based on how SVGR generates a component name:
- // https://github.com/smooth-code/svgr/blob/01b194cf967347d43d4cbe6b434404731b87cf27/packages/core/src/state.js#L6
- const pascalCaseFilename = camelcase(path.parse(filename).name, {
- pascalCase: true,
- });
- const componentName = `Svg${pascalCaseFilename}`;
- return `const React = require('react');
- module.exports = {
- __esModule: true,
- default: ${assetFilename},
- ReactComponent: React.forwardRef(function ${componentName}(props, ref) {
- return {
- $$typeof: Symbol.for('react.element'),
- type: 'svg',
- ref: ref,
- key: null,
- props: Object.assign({}, props, {
- children: ${assetFilename}
- })
- };
- }),
- };`;
- }
-
- return `module.exports = ${assetFilename};`;
- },
-};
diff --git a/config/jest/setEnvVars.js b/config/jest/setEnvVars.js
deleted file mode 100644
index ac7e1d8..0000000
--- a/config/jest/setEnvVars.js
+++ /dev/null
@@ -1,2 +0,0 @@
-const envConfig = require("../../" + (process.env.CONFIG || 'config.js'));
-process.env = { ...process.env, ...envConfig };
diff --git a/config/modules.js b/config/modules.js
deleted file mode 100644
index d63e41d..0000000
--- a/config/modules.js
+++ /dev/null
@@ -1,134 +0,0 @@
-'use strict';
-
-const fs = require('fs');
-const path = require('path');
-const paths = require('./paths');
-const chalk = require('react-dev-utils/chalk');
-const resolve = require('resolve');
-
-/**
- * Get additional module paths based on the baseUrl of a compilerOptions object.
- *
- * @param {Object} options
- */
-function getAdditionalModulePaths(options = {}) {
- const baseUrl = options.baseUrl;
-
- if (!baseUrl) {
- return '';
- }
-
- const baseUrlResolved = path.resolve(paths.appPath, baseUrl);
-
- // We don't need to do anything if `baseUrl` is set to `node_modules`. This is
- // the default behavior.
- if (path.relative(paths.appNodeModules, baseUrlResolved) === '') {
- return null;
- }
-
- // Allow the user set the `baseUrl` to `appSrc`.
- if (path.relative(paths.appSrc, baseUrlResolved) === '') {
- return [paths.appSrc];
- }
-
- // If the path is equal to the root directory we ignore it here.
- // We don't want to allow importing from the root directly as source files are
- // not transpiled outside of `src`. We do allow importing them with the
- // absolute path (e.g. `src/Components/Button.js`) but we set that up with
- // an alias.
- if (path.relative(paths.appPath, baseUrlResolved) === '') {
- return null;
- }
-
- // Otherwise, throw an error.
- throw new Error(
- chalk.red.bold(
- "Your project's `baseUrl` can only be set to `src` or `node_modules`." +
- ' Create React App does not support other values at this time.'
- )
- );
-}
-
-/**
- * Get webpack aliases based on the baseUrl of a compilerOptions object.
- *
- * @param {*} options
- */
-function getWebpackAliases(options = {}) {
- const baseUrl = options.baseUrl;
-
- if (!baseUrl) {
- return {};
- }
-
- const baseUrlResolved = path.resolve(paths.appPath, baseUrl);
-
- if (path.relative(paths.appPath, baseUrlResolved) === '') {
- return {
- src: paths.appSrc,
- };
- }
-}
-
-/**
- * Get jest aliases based on the baseUrl of a compilerOptions object.
- *
- * @param {*} options
- */
-function getJestAliases(options = {}) {
- const baseUrl = options.baseUrl;
-
- if (!baseUrl) {
- return {};
- }
-
- const baseUrlResolved = path.resolve(paths.appPath, baseUrl);
-
- if (path.relative(paths.appPath, baseUrlResolved) === '') {
- return {
- '^src/(.*)$': '/src/$1',
- };
- }
-}
-
-function getModules() {
- // Check if TypeScript is setup
- const hasTsConfig = fs.existsSync(paths.appTsConfig);
- const hasJsConfig = fs.existsSync(paths.appJsConfig);
-
- if (hasTsConfig && hasJsConfig) {
- throw new Error(
- 'You have both a tsconfig.json and a jsconfig.json. If you are using TypeScript please remove your jsconfig.json file.'
- );
- }
-
- let config;
-
- // If there's a tsconfig.json we assume it's a
- // TypeScript project and set up the config
- // based on tsconfig.json
- if (hasTsConfig) {
- const ts = require(resolve.sync('typescript', {
- basedir: paths.appNodeModules,
- }));
- config = ts.readConfigFile(paths.appTsConfig, ts.sys.readFile).config;
- // Otherwise we'll check if there is jsconfig.json
- // for non TS projects.
- } else if (hasJsConfig) {
- config = require(paths.appJsConfig);
- }
-
- config = config || {};
- const options = config.compilerOptions || {};
-
- const additionalModulePaths = getAdditionalModulePaths(options);
-
- return {
- additionalModulePaths: additionalModulePaths,
- webpackAliases: getWebpackAliases(options),
- jestAliases: getJestAliases(options),
- hasTsConfig,
- };
-}
-
-module.exports = getModules();
diff --git a/config/paths.js b/config/paths.js
deleted file mode 100644
index 59c6d04..0000000
--- a/config/paths.js
+++ /dev/null
@@ -1,73 +0,0 @@
-'use strict';
-
-const path = require('path');
-const fs = require('fs');
-const getPublicUrlOrPath = require('react-dev-utils/getPublicUrlOrPath');
-
-// Make sure any symlinks in the project folder are resolved:
-// https://github.com/facebook/create-react-app/issues/637
-const appDirectory = fs.realpathSync(process.cwd());
-const resolveApp = relativePath => path.resolve(appDirectory, relativePath);
-
-// We use `PUBLIC_URL` environment variable or "homepage" field to infer
-// "public path" at which the app is served.
-// webpack needs to know it to put the right