From 1cf870d0271ae90179c7e64b8ef28c64d1fb834b Mon Sep 17 00:00:00 2001
From: dudor
Date: Wed, 18 Dec 2024 07:12:22 +0800
Subject: [PATCH 1/3] mv3
---
.gitignore | 43 +-
LICENSE | 201 -
README.md | 99 +-
README_cn.md | 96 -
config/env.js | 106 -
config/getHttpsConfig.js | 66 -
config/jest/babelTransform.js | 29 -
config/jest/cssTransform.js | 14 -
config/jest/fileTransform.js | 40 -
config/modules.js | 134 -
config/paths.js | 75 -
config/pnpTs.js | 35 -
config/webpack.config.js | 761 -
config/webpackDevServer.config.js | 130 -
images/1.png | Bin 181449 -> 0 bytes
images/2.png | Bin 113377 -> 0 bytes
images/3.gif | Bin 1483670 -> 0 bytes
package.json | 205 +-
pnpm-lock.yaml | 5032 +++++++
public/icons/icon128.png | Bin 4268 -> 0 bytes
public/icons/icon32.png | Bin 4233 -> 0 bytes
public/manifest.json | 36 -
scripts/build.js | 214 -
scripts/start.js | 166 -
scripts/test.js | 53 -
src/App.css | 38 -
src/App.test.tsx | 9 -
src/App.tsx | 26 -
src/assets/react.svg | 1 +
src/entrypoints/background.ts | 383 +
src/entrypoints/options/index.html | 17 +
.../options/options.css | 0
.../options/options.tsx | 12 +-
src/entrypoints/popup/index.html | 13 +
src/{views => entrypoints}/popup/popup.css | 0
src/{views => entrypoints}/popup/popup.tsx | 12 +-
src/icons/icon128.png | Bin 4268 -> 0 bytes
src/icons/icon16.png | Bin 416 -> 0 bytes
src/icons/icon19.png | Bin 469 -> 0 bytes
src/icons/icon48.png | Bin 1208 -> 0 bytes
src/icons/icon64.png | Bin 1666 -> 0 bytes
src/index.css | 13 -
src/index.tsx | 17 -
src/logo.svg | 1 -
.../public}/_locales/en/messages.json | 0
.../public}/_locales/zh_CN/messages.json | 0
{images => src/public/icon}/icon128.png | Bin
{public/icons => src/public/icon}/icon16.png | Bin
{public/icons => src/public/icon}/icon19.png | Bin
{public/icons => src/public/icon}/icon48.png | Bin
{public/icons => src/public/icon}/icon64.png | Bin
src/public/wxt.svg | 15 +
src/react-app-env.d.ts | 71 -
src/reportWebVitals.ts | 15 -
src/setupTests.ts | 5 -
src/utils/http.ts | 57 +-
src/utils/optionsStorage.ts | 1 -
src/utils/services.ts | 18 +-
src/utils/setting.ts | 25 +
src/views/background/background.html | 41 -
src/views/background/background.tsx | 361 -
src/views/options/options.html | 41 -
src/views/popup/popup.html | 41 -
tools.js | 71 -
tsconfig.json | 25 +-
wxt.config.ts | 18 +
yarn.lock | 11567 ----------------
67 files changed, 5615 insertions(+), 14834 deletions(-)
delete mode 100644 LICENSE
delete mode 100644 README_cn.md
delete mode 100644 config/env.js
delete mode 100644 config/getHttpsConfig.js
delete mode 100644 config/jest/babelTransform.js
delete mode 100644 config/jest/cssTransform.js
delete mode 100644 config/jest/fileTransform.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 images/1.png
delete mode 100644 images/2.png
delete mode 100644 images/3.gif
create mode 100644 pnpm-lock.yaml
delete mode 100644 public/icons/icon128.png
delete mode 100644 public/icons/icon32.png
delete mode 100644 public/manifest.json
delete mode 100644 scripts/build.js
delete mode 100644 scripts/start.js
delete mode 100644 scripts/test.js
delete mode 100644 src/App.css
delete mode 100644 src/App.test.tsx
delete mode 100644 src/App.tsx
create mode 100644 src/assets/react.svg
create mode 100644 src/entrypoints/background.ts
create mode 100644 src/entrypoints/options/index.html
rename src/{views => entrypoints}/options/options.css (100%)
rename src/{views => entrypoints}/options/options.tsx (95%)
create mode 100644 src/entrypoints/popup/index.html
rename src/{views => entrypoints}/popup/popup.css (100%)
rename src/{views => entrypoints}/popup/popup.tsx (94%)
delete mode 100644 src/icons/icon128.png
delete mode 100644 src/icons/icon16.png
delete mode 100644 src/icons/icon19.png
delete mode 100644 src/icons/icon48.png
delete mode 100644 src/icons/icon64.png
delete mode 100644 src/index.css
delete mode 100644 src/index.tsx
delete mode 100644 src/logo.svg
rename {public => src/public}/_locales/en/messages.json (100%)
rename {public => src/public}/_locales/zh_CN/messages.json (100%)
rename {images => src/public/icon}/icon128.png (100%)
rename {public/icons => src/public/icon}/icon16.png (100%)
rename {public/icons => src/public/icon}/icon19.png (100%)
rename {public/icons => src/public/icon}/icon48.png (100%)
rename {public/icons => src/public/icon}/icon64.png (100%)
create mode 100644 src/public/wxt.svg
delete mode 100644 src/react-app-env.d.ts
delete mode 100644 src/reportWebVitals.ts
delete mode 100644 src/setupTests.ts
delete mode 100644 src/views/background/background.html
delete mode 100644 src/views/background/background.tsx
delete mode 100644 src/views/options/options.html
delete mode 100644 src/views/popup/popup.html
delete mode 100644 tools.js
create mode 100644 wxt.config.ts
delete mode 100644 yarn.lock
diff --git a/.gitignore b/.gitignore
index 4d29575..a256953 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,23 +1,26 @@
-# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
-
-# dependencies
-/node_modules
-/.pnp
-.pnp.js
-
-# testing
-/coverage
-
-# production
-/build
-
-# misc
-.DS_Store
-.env.local
-.env.development.local
-.env.test.local
-.env.production.local
-
+# Logs
+logs
+*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
+pnpm-debug.log*
+lerna-debug.log*
+
+node_modules
+.output
+stats.html
+stats-*.json
+.wxt
+web-ext.config.ts
+
+# Editor directories and files
+.vscode/*
+!.vscode/extensions.json
+.idea
+.DS_Store
+*.suo
+*.ntvs*
+*.njsproj
+*.sln
+*.sw?
diff --git a/LICENSE b/LICENSE
deleted file mode 100644
index 261eeb9..0000000
--- a/LICENSE
+++ /dev/null
@@ -1,201 +0,0 @@
- Apache License
- Version 2.0, January 2004
- http://www.apache.org/licenses/
-
- TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
-
- 1. Definitions.
-
- "License" shall mean the terms and conditions for use, reproduction,
- and distribution as defined by Sections 1 through 9 of this document.
-
- "Licensor" shall mean the copyright owner or entity authorized by
- the copyright owner that is granting the License.
-
- "Legal Entity" shall mean the union of the acting entity and all
- other entities that control, are controlled by, or are under common
- control with that entity. For the purposes of this definition,
- "control" means (i) the power, direct or indirect, to cause the
- direction or management of such entity, whether by contract or
- otherwise, or (ii) ownership of fifty percent (50%) or more of the
- outstanding shares, or (iii) beneficial ownership of such entity.
-
- "You" (or "Your") shall mean an individual or Legal Entity
- exercising permissions granted by this License.
-
- "Source" form shall mean the preferred form for making modifications,
- including but not limited to software source code, documentation
- source, and configuration files.
-
- "Object" form shall mean any form resulting from mechanical
- transformation or translation of a Source form, including but
- not limited to compiled object code, generated documentation,
- and conversions to other media types.
-
- "Work" shall mean the work of authorship, whether in Source or
- Object form, made available under the License, as indicated by a
- copyright notice that is included in or attached to the work
- (an example is provided in the Appendix below).
-
- "Derivative Works" shall mean any work, whether in Source or Object
- form, that is based on (or derived from) the Work and for which the
- editorial revisions, annotations, elaborations, or other modifications
- represent, as a whole, an original work of authorship. For the purposes
- of this License, Derivative Works shall not include works that remain
- separable from, or merely link (or bind by name) to the interfaces of,
- the Work and Derivative Works thereof.
-
- "Contribution" shall mean any work of authorship, including
- the original version of the Work and any modifications or additions
- to that Work or Derivative Works thereof, that is intentionally
- submitted to Licensor for inclusion in the Work by the copyright owner
- or by an individual or Legal Entity authorized to submit on behalf of
- the copyright owner. For the purposes of this definition, "submitted"
- means any form of electronic, verbal, or written communication sent
- to the Licensor or its representatives, including but not limited to
- communication on electronic mailing lists, source code control systems,
- and issue tracking systems that are managed by, or on behalf of, the
- Licensor for the purpose of discussing and improving the Work, but
- excluding communication that is conspicuously marked or otherwise
- designated in writing by the copyright owner as "Not a Contribution."
-
- "Contributor" shall mean Licensor and any individual or Legal Entity
- on behalf of whom a Contribution has been received by Licensor and
- subsequently incorporated within the Work.
-
- 2. Grant of Copyright License. Subject to the terms and conditions of
- this License, each Contributor hereby grants to You a perpetual,
- worldwide, non-exclusive, no-charge, royalty-free, irrevocable
- copyright license to reproduce, prepare Derivative Works of,
- publicly display, publicly perform, sublicense, and distribute the
- Work and such Derivative Works in Source or Object form.
-
- 3. Grant of Patent License. Subject to the terms and conditions of
- this License, each Contributor hereby grants to You a perpetual,
- worldwide, non-exclusive, no-charge, royalty-free, irrevocable
- (except as stated in this section) patent license to make, have made,
- use, offer to sell, sell, import, and otherwise transfer the Work,
- where such license applies only to those patent claims licensable
- by such Contributor that are necessarily infringed by their
- Contribution(s) alone or by combination of their Contribution(s)
- with the Work to which such Contribution(s) was submitted. If You
- institute patent litigation against any entity (including a
- cross-claim or counterclaim in a lawsuit) alleging that the Work
- or a Contribution incorporated within the Work constitutes direct
- or contributory patent infringement, then any patent licenses
- granted to You under this License for that Work shall terminate
- as of the date such litigation is filed.
-
- 4. Redistribution. You may reproduce and distribute copies of the
- Work or Derivative Works thereof in any medium, with or without
- modifications, and in Source or Object form, provided that You
- meet the following conditions:
-
- (a) You must give any other recipients of the Work or
- Derivative Works a copy of this License; and
-
- (b) You must cause any modified files to carry prominent notices
- stating that You changed the files; and
-
- (c) You must retain, in the Source form of any Derivative Works
- that You distribute, all copyright, patent, trademark, and
- attribution notices from the Source form of the Work,
- excluding those notices that do not pertain to any part of
- the Derivative Works; and
-
- (d) If the Work includes a "NOTICE" text file as part of its
- distribution, then any Derivative Works that You distribute must
- include a readable copy of the attribution notices contained
- within such NOTICE file, excluding those notices that do not
- pertain to any part of the Derivative Works, in at least one
- of the following places: within a NOTICE text file distributed
- as part of the Derivative Works; within the Source form or
- documentation, if provided along with the Derivative Works; or,
- within a display generated by the Derivative Works, if and
- wherever such third-party notices normally appear. The contents
- of the NOTICE file are for informational purposes only and
- do not modify the License. You may add Your own attribution
- notices within Derivative Works that You distribute, alongside
- or as an addendum to the NOTICE text from the Work, provided
- that such additional attribution notices cannot be construed
- as modifying the License.
-
- You may add Your own copyright statement to Your modifications and
- may provide additional or different license terms and conditions
- for use, reproduction, or distribution of Your modifications, or
- for any such Derivative Works as a whole, provided Your use,
- reproduction, and distribution of the Work otherwise complies with
- the conditions stated in this License.
-
- 5. Submission of Contributions. Unless You explicitly state otherwise,
- any Contribution intentionally submitted for inclusion in the Work
- by You to the Licensor shall be under the terms and conditions of
- this License, without any additional terms or conditions.
- Notwithstanding the above, nothing herein shall supersede or modify
- the terms of any separate license agreement you may have executed
- with Licensor regarding such Contributions.
-
- 6. Trademarks. This License does not grant permission to use the trade
- names, trademarks, service marks, or product names of the Licensor,
- except as required for reasonable and customary use in describing the
- origin of the Work and reproducing the content of the NOTICE file.
-
- 7. Disclaimer of Warranty. Unless required by applicable law or
- agreed to in writing, Licensor provides the Work (and each
- Contributor provides its Contributions) on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
- implied, including, without limitation, any warranties or conditions
- of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
- PARTICULAR PURPOSE. You are solely responsible for determining the
- appropriateness of using or redistributing the Work and assume any
- risks associated with Your exercise of permissions under this License.
-
- 8. Limitation of Liability. In no event and under no legal theory,
- whether in tort (including negligence), contract, or otherwise,
- unless required by applicable law (such as deliberate and grossly
- negligent acts) or agreed to in writing, shall any Contributor be
- liable to You for damages, including any direct, indirect, special,
- incidental, or consequential damages of any character arising as a
- result of this License or out of the use or inability to use the
- Work (including but not limited to damages for loss of goodwill,
- work stoppage, computer failure or malfunction, or any and all
- other commercial damages or losses), even if such Contributor
- has been advised of the possibility of such damages.
-
- 9. Accepting Warranty or Additional Liability. While redistributing
- the Work or Derivative Works thereof, You may choose to offer,
- and charge a fee for, acceptance of support, warranty, indemnity,
- or other liability obligations and/or rights consistent with this
- License. However, in accepting such obligations, You may act only
- on Your own behalf and on Your sole responsibility, not on behalf
- of any other Contributor, and only if You agree to indemnify,
- defend, and hold each Contributor harmless for any liability
- incurred by, or claims asserted against, such Contributor by reason
- of your accepting any such warranty or additional liability.
-
- END OF TERMS AND CONDITIONS
-
- APPENDIX: How to apply the Apache License to your work.
-
- To apply the Apache License to your work, attach the following
- boilerplate notice, with the fields enclosed by brackets "[]"
- replaced with your own identifying information. (Don't include
- the brackets!) The text should be enclosed in the appropriate
- comment syntax for the file format. We also recommend that a
- file or class name and description of purpose be included on the
- same "printed page" as the copyright notice for easier
- identification within third-party archives.
-
- Copyright [yyyy] [name of copyright owner]
-
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
-
- http://www.apache.org/licenses/LICENSE-2.0
-
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
diff --git a/README.md b/README.md
index bfbcbd1..78cf194 100644
--- a/README.md
+++ b/README.md
@@ -1,98 +1,3 @@
+# WXT + React
-
-
-
-
-
-
-
-
BookmarkHub
-
- BookmarkHub is a browser plug-in that can synchronize your bookmarks between different browsers.
-
- Feedback
- ·
- 简体中文
- ·
- English
-
-
-
-
-
- Table of Contents
-
- - About The Project
- - Features
- - Installation
- - Usage
- - Roadmap
- - License
- - Contact
-
-
-
-
-## About The Project
-
-BookmarkHub is a browser plug-in that can synchronize your bookmarks between different browsers.
-
-For major browsers such as Chrome, Firefox, Microsoft Edge, and more.
-
-It uses GitHub's Gist records to store browser bookmarks for safe and secure use.
-
-![BookmarkHub](images/3.gif)
-
-![BookmarkHub](images/1.png)
-
-![BookmarkHub](images/2.png)
-
-## Features
-* No registration required, just use the Token and Gist of your GitHub account
-* Easy to upload and download bookmarks with one click
-* Clear all local bookmarks with one click
-* Support cross-machine and cross-browser synchronization of bookmarks
-* Support to display the number of local and remote bookmarks
-
-
-## Installation
-> This plug-in requires bookmarks to be stored in Gist, so make sure you have a GitHub account or register your GitHub account over the network.
-* [Chrome](https://chrome.google.com/webstore/detail/bookmarkhub-sync-bookmark/fohimdklhhcpcnpmmichieidclgfdmol)
-* [Firefox](https://addons.mozilla.org/en/firefox/addon/BookmarkHub/)
-* [Microsoft Edge](https://microsoftedge.microsoft.com/addons/detail/BookmarkHub/fdnmfpogadcljhecfhdikdecbkggfmgk)
-* Opera
-* Other browsers based on the Chromium kernel
-
-
-## Usage
-
-1. [Login](https://github.com/login) GitHub,If you don't have an account, please [click here to register](https://github.com/join)。
-2. [Create a token that manages the gist](https://github.com/settings/tokens/new)。
-3. [Create a secret gist](https://gist.github.com)。__Note: If it's a public gist, your bookmarks can be searched by others。__
-4. Download BookmarkHub in the browser store, click the plug-in's settings button, fill in the token and gist ID in the pop-up settings window, and you can upload the download bookmark。
-
-
-## Roadmap
-
-- [ ] Automatically sync bookmarks
-- [ ] Support webdav protocol
-- [ ] Mobile app
-- [ ] Import and Export
-- [ ] Share bookmarks
-
-
-## License
-
-See `LICENSE` for more information.
-
-
-
-
-## Contact
-
-dudor
-
-Project Link: [https://github.com/dudor/BookmarkHub](https://github.com/dudor/BookmarkHub)
-
-
-
+This template should help get you started developing with React in WXT.
diff --git a/README_cn.md b/README_cn.md
deleted file mode 100644
index 3d40414..0000000
--- a/README_cn.md
+++ /dev/null
@@ -1,96 +0,0 @@
-
-
-
-
-
-
-
-
-
BookmarkHub
-
- BookmarkHub 是一款浏览器插件,可以在不同浏览器之间同步你的书签。
-
- 反馈问题
- ·
- 简体中文
- ·
- English
-
-
-
-
-
- 目录
-
- - 关于
- - 功能
- - 下载安装
- - 使用方法
- - 待实现的功能
- - License
- - Contact
-
-
-
-
-## 关于
-
-BookmarkHub 是一款浏览器插件,可以在不同浏览器之间同步你的书签。
-
-适用于各大主流浏览器,如 Chrome、Firefox、Microsoft Edge 等。
-
-它使用 GitHub 的 Gist 记录来存储浏览器的书签,可以放心安全的使用。
-
-![BookmarkHub](images/3.gif)
-
-![BookmarkHub](images/1.png)
-
-![BookmarkHub](images/2.png)
-
-## 功能
-* 不需要注册特殊账号,只需要用你的 GitHub 账号的Token和Gist
-* 一键上传下载书签
-* 一键清空本地所有书签
-* 支持跨电脑跨浏览器同步书签
-* 支持显示本地和远程书签的数量
-
-## 下载安装
-> 本插件需要把书签存储到 Gist 中,所以请确保有 GitHub 账号或可以通过网络注册 GitHub 账号。
-* [Chrome 浏览器](https://chrome.google.com/webstore/detail/bookmarkhub-sync-bookmark/fohimdklhhcpcnpmmichieidclgfdmol)
-* [Firefox 浏览器](https://addons.mozilla.org/zh-CN/firefox/addon/BookmarkHub/)
-* [Microsoft Edge 浏览器](https://microsoftedge.microsoft.com/addons/detail/BookmarkHub/fdnmfpogadcljhecfhdikdecbkggfmgk)
-* Opera 浏览器
-* 其他基于 Chromium 内核的浏览器
-
-
-## 使用方法
-
-1. [登陆](https://github.com/login) GitHub,如果没有账号请点此[注册](https://github.com/join)。
-2. [创建一个可以管理 gist 的 token](https://github.com/settings/tokens/new)。
-3. [创建一个私有的 gist](https://gist.github.com)。__注意:如果是公开的 gist,你的书签是可以被他人搜索到的。__
-4. 在浏览器的应用商店下载 BookmarkHub,点击插件的设置按钮,在弹出的设置窗口填入 token 和 gist ID,然后你就可以上传下载书签了。
-
-
-## 待实现的功能
-
-- [ ] 自动同步书签
-- [ ] 支持 webdav 协议
-- [ ] 移动端
-- [ ] 导入导出
-- [ ] 分享书签
-
-
-
-## License
-
-See `LICENSE` for more information.
-
-
-## Contact
-
-dudor
-
-Project Link: [https://github.com/dudor/BookmarkHub](https://github.com/dudor/BookmarkHub)
-
-
-
diff --git a/config/env.js b/config/env.js
deleted file mode 100644
index 3d1411b..0000000
--- a/config/env.js
+++ /dev/null
@@ -1,106 +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')];
-
-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;
- }, {}),
- };
-
- 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/babelTransform.js b/config/jest/babelTransform.js
deleted file mode 100644
index dabf5a8..0000000
--- a/config/jest/babelTransform.js
+++ /dev/null
@@ -1,29 +0,0 @@
-'use strict';
-
-const babelJest = require('babel-jest');
-
-const hasJsxRuntime = (() => {
- if (process.env.DISABLE_NEW_JSX_TRANSFORM === 'true') {
- return false;
- }
-
- try {
- require.resolve('react/jsx-runtime');
- return true;
- } catch (e) {
- return false;
- }
-})();
-
-module.exports = babelJest.createTransformer({
- presets: [
- [
- require.resolve('babel-preset-react-app'),
- {
- runtime: hasJsxRuntime ? 'automatic' : 'classic',
- },
- ],
- ],
- babelrc: false,
- configFile: false,
-});
diff --git a/config/jest/cssTransform.js b/config/jest/cssTransform.js
deleted file mode 100644
index 8f65114..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 aab6761..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/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 ea402d8..0000000
--- a/config/paths.js
+++ /dev/null
@@ -1,75 +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
+