ezuikit-js 0.6.1-beta.4 → 0.6.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (159) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/README.md +45 -5
  3. package/demos/base-demo/base.html +117 -0
  4. package/demos/base-demo/ezuikit.js +8567 -6436
  5. package/demos/base-demo/ezuikit_static/v6/v1/css/theme.css +121 -0
  6. package/demos/base-demo/ezuikit_static/v6/v1/js/jsPluginV1-1.0.0.min.js +2 -2
  7. package/demos/base-demo/ezuikit_static/v6/v1/js/playctrl/AudioRenderer.js +5 -5
  8. package/demos/base-demo/ezuikit_static/v6/v1/js/playctrl/DecodeWorker.js +130 -223
  9. package/demos/base-demo/ezuikit_static/v6/v1/js/playctrl/Decoder.js +1 -1
  10. package/demos/base-demo/ezuikit_static/v6/v1/js/playctrl/JSPlaySDKInterface.js +201 -667
  11. package/demos/base-demo/ezuikit_static/v6/v1/js/playctrl/SuperRender_10.js +9 -8
  12. package/demos/base-demo/ezuikit_static/v6/v1/speed/speed.css +144 -0
  13. package/demos/base-demo/ezuikit_static/v6/v2/css/theme.css +121 -0
  14. package/demos/base-demo/ezuikit_static/v6/v2/js/jsPluginV2-2.0.1.min.js +147 -65
  15. package/demos/base-demo/ezuikit_static/v6/v2/speed/speed.css +144 -0
  16. package/demos/base-demo/hls.html +24 -0
  17. package/demos/base-demo/index.html +11 -16
  18. package/demos/base-demo/localDecoder.html +118 -0
  19. package/demos/base-demo/mobileLive.html +117 -0
  20. package/demos/base-demo/mobileRec.html +116 -0
  21. package/demos/base-demo/multi.html +129 -0
  22. package/demos/base-demo/pcLive.html +117 -0
  23. package/demos/base-demo/pcRec.html +116 -0
  24. package/demos/base-demo/template.html +124 -0
  25. package/demos/base-demo/themeData.html +232 -0
  26. package/demos/nginx-demo/contrib/README +21 -21
  27. package/demos/nginx-demo/contrib/unicode2nginx/koi-utf +131 -131
  28. package/demos/nginx-demo/contrib/unicode2nginx/unicode-to-nginx.pl +48 -48
  29. package/demos/nginx-demo/contrib/unicode2nginx/win-utf +130 -130
  30. package/demos/nginx-demo/contrib/vim/ftdetect/nginx.vim +4 -4
  31. package/demos/nginx-demo/contrib/vim/ftplugin/nginx.vim +1 -1
  32. package/demos/nginx-demo/contrib/vim/indent/nginx.vim +11 -11
  33. package/demos/nginx-demo/contrib/vim/syntax/nginx.vim +2268 -2268
  34. package/demos/nginx-demo/docs/CHANGES +8115 -8115
  35. package/demos/nginx-demo/docs/CHANGES.ru +8252 -8252
  36. package/demos/nginx-demo/docs/LICENSE +26 -26
  37. package/demos/nginx-demo/docs/OpenSSL.LICENSE +127 -127
  38. package/demos/nginx-demo/docs/PCRE.LICENCE +93 -93
  39. package/demos/nginx-demo/docs/README +3 -3
  40. package/demos/nginx-demo/docs/zlib.LICENSE +20 -20
  41. package/demos/nginx-demo/html/50x.html +21 -21
  42. package/demos/nginx-demo/html/ezuikit5/ezuikit.js +8893 -6480
  43. package/demos/nginx-demo/html/ezuikit5/index.html +10 -3
  44. package/demos/nginx-demo/html/index.html +16 -16
  45. package/demos/react-demo/package-lock.json +13953 -0
  46. package/demos/react-demo/package.json +36 -141
  47. package/demos/react-demo/src/App.js +72 -12
  48. package/demos/vue-demo/README.md +24 -0
  49. package/demos/vue-demo/babel.config.js +5 -0
  50. package/demos/vue-demo/package-lock.json +11638 -0
  51. package/demos/vue-demo/package.json +43 -0
  52. package/demos/vue-demo/public/favicon.ico +0 -0
  53. package/demos/vue-demo/public/index.html +17 -0
  54. package/demos/vue-demo/src/App.vue +27 -0
  55. package/demos/vue-demo/src/assets/logo.png +0 -0
  56. package/demos/vue-demo/src/components/EZUIKitJs.vue +115 -0
  57. package/demos/vue-demo/src/main.js +8 -0
  58. package/ezuikit.js +8567 -6436
  59. package/package.json +1 -1
  60. package/demos/base-demo/ezuikit_static/v6/v1/Decoder.js +0 -9195
  61. package/demos/base-demo/ezuikit_static/v6/v1/Decoder.wasm +0 -0
  62. package/demos/base-demo/ezuikit_static/v6/v1/ezuikit.js +0 -2334
  63. package/demos/base-demo/ezuikit_static/v6/v1/js/jsPlugin-4.0.0.min.js +0 -26
  64. package/demos/base-demo/ezuikit_static/v6/v1/js/jsPlugin-4.0.1.min.js +0 -26
  65. package/demos/base-demo/ezuikit_static/v6/v1/js/jsPlugin-4.0.2.min.js +0 -26
  66. package/demos/base-demo/ezuikit_static/v6/v1/jsPlugin-2.0.0.min.js +0 -5219
  67. package/demos/base-demo/ezuikit_static/v6/v2/Decoder.js +0 -9195
  68. package/demos/base-demo/ezuikit_static/v6/v2/Decoder.wasm +0 -0
  69. package/demos/base-demo/ezuikit_static/v6/v2/js/AudioRenderer.js +0 -225
  70. package/demos/base-demo/ezuikit_static/v6/v2/js/SuperRender_10.js +0 -395
  71. package/demos/base-demo/ezuikit_static/v6/v2/js/SystemTransform.js +0 -22
  72. package/demos/base-demo/ezuikit_static/v6/v2/js/SystemTransform.js.mem +0 -0
  73. package/demos/base-demo/ezuikit_static/v6/v2/js/jsPlugin-4.0.0.min.js +0 -26
  74. package/demos/base-demo/ezuikit_static/v6/v2/js/jsPlugin-4.0.1.min.js +0 -26
  75. package/demos/base-demo/ezuikit_static/v6/v2/js/jsPlugin-4.0.2.min.js +0 -26
  76. package/demos/base-demo/ezuikit_static/v6/v2/js/playctrl/AudioRenderer.js +0 -225
  77. package/demos/base-demo/ezuikit_static/v6/v2/js/playctrl/DecodeWorker.js +0 -711
  78. package/demos/base-demo/ezuikit_static/v6/v2/js/playctrl/Decoder.js +0 -1
  79. package/demos/base-demo/ezuikit_static/v6/v2/js/playctrl/JSPlaySDKInterface.js +0 -2518
  80. package/demos/base-demo/ezuikit_static/v6/v2/js/playctrl/SuperRender_10.js +0 -395
  81. package/demos/base-demo/ezuikit_static/v6/v2/js/playctrl/SuperRender_20.js +0 -1
  82. package/demos/base-demo/ezuikit_static/v6/v2/js/transform/SystemTransform.js +0 -22
  83. package/demos/base-demo/ezuikit_static/v6/v2/js/transform/SystemTransform.js.mem +0 -0
  84. package/demos/base-demo/ezuikit_static/v6/v2/js/transform/systemTransform-worker.min.js +0 -1
  85. package/demos/base-demo/ezuikit_static/v6/v2/js/tts-v4.js +0 -343
  86. package/demos/base-demo/ezuikit_static/v6/v2/jsPlugin-2.0.1.min.js +0 -5319
  87. package/demos/base-demo/ezuikit_static/v6/v2/jsPluginV2-2.0.1.min.js +0 -5294
  88. package/demos/base-demo/server.js +0 -67
  89. package/demos/react-demo/config/env.js +0 -101
  90. package/demos/react-demo/config/getHttpsConfig.js +0 -66
  91. package/demos/react-demo/config/jest/cssTransform.js +0 -14
  92. package/demos/react-demo/config/jest/fileTransform.js +0 -40
  93. package/demos/react-demo/config/modules.js +0 -141
  94. package/demos/react-demo/config/paths.js +0 -72
  95. package/demos/react-demo/config/pnpTs.js +0 -35
  96. package/demos/react-demo/config/webpack.config.js +0 -669
  97. package/demos/react-demo/config/webpackDevServer.config.js +0 -134
  98. package/demos/react-demo/scripts/build.js +0 -211
  99. package/demos/react-demo/scripts/start.js +0 -166
  100. package/demos/react-demo/scripts/test.js +0 -53
  101. package/ezuikit_static/v6/v1/Decoder.js +0 -9195
  102. package/ezuikit_static/v6/v1/Decoder.wasm +0 -0
  103. package/ezuikit_static/v6/v1/ezuikit.js +0 -2334
  104. package/ezuikit_static/v6/v1/js/AudioRenderer.js +0 -225
  105. package/ezuikit_static/v6/v1/js/SuperRender_10.js +0 -395
  106. package/ezuikit_static/v6/v1/js/SystemTransform.js +0 -22
  107. package/ezuikit_static/v6/v1/js/SystemTransform.js.mem +0 -0
  108. package/ezuikit_static/v6/v1/js/jsPlugin-4.0.0.min.js +0 -26
  109. package/ezuikit_static/v6/v1/js/jsPlugin-4.0.1.min.js +0 -26
  110. package/ezuikit_static/v6/v1/js/jsPlugin-4.0.2.min.js +0 -26
  111. package/ezuikit_static/v6/v1/js/jsPluginV1-1.0.0.min.js +0 -26
  112. package/ezuikit_static/v6/v1/js/playctrl/AudioRenderer.js +0 -225
  113. package/ezuikit_static/v6/v1/js/playctrl/DecodeWorker.js +0 -711
  114. package/ezuikit_static/v6/v1/js/playctrl/Decoder.js +0 -1
  115. package/ezuikit_static/v6/v1/js/playctrl/JSPlaySDKInterface.js +0 -2518
  116. package/ezuikit_static/v6/v1/js/playctrl/SuperRender_10.js +0 -395
  117. package/ezuikit_static/v6/v1/js/playctrl/SuperRender_20.js +0 -1
  118. package/ezuikit_static/v6/v1/js/transform/SystemTransform.js +0 -22
  119. package/ezuikit_static/v6/v1/js/transform/SystemTransform.js.mem +0 -0
  120. package/ezuikit_static/v6/v1/js/transform/systemTransform-worker.min.js +0 -1
  121. package/ezuikit_static/v6/v1/js/tts-v4.js +0 -346
  122. package/ezuikit_static/v6/v1/jsPlugin-2.0.0.min.js +0 -5219
  123. package/ezuikit_static/v6/v1/rec/datepicker.js +0 -1522
  124. package/ezuikit_static/v6/v1/rec/datepicker.min.css +0 -27
  125. package/ezuikit_static/v6/v1/rec/datepicker.zh-CN.js +0 -19
  126. package/ezuikit_static/v6/v1/rec/jquery.min.js +0 -2
  127. package/ezuikit_static/v6/v1/talk/adapeter.js +0 -5497
  128. package/ezuikit_static/v6/v1/talk/janus.js +0 -3507
  129. package/ezuikit_static/v6/v1/talk/tts-v4.js +0 -346
  130. package/ezuikit_static/v6/v2/Decoder.js +0 -9195
  131. package/ezuikit_static/v6/v2/Decoder.wasm +0 -0
  132. package/ezuikit_static/v6/v2/js/AudioRenderer.js +0 -225
  133. package/ezuikit_static/v6/v2/js/Decoder.js +0 -9195
  134. package/ezuikit_static/v6/v2/js/Decoder.wasm +0 -0
  135. package/ezuikit_static/v6/v2/js/SuperRender_10.js +0 -395
  136. package/ezuikit_static/v6/v2/js/SystemTransform.js +0 -22
  137. package/ezuikit_static/v6/v2/js/SystemTransform.js.mem +0 -0
  138. package/ezuikit_static/v6/v2/js/jsPlugin-4.0.0.min.js +0 -26
  139. package/ezuikit_static/v6/v2/js/jsPlugin-4.0.1.min.js +0 -26
  140. package/ezuikit_static/v6/v2/js/jsPlugin-4.0.2.min.js +0 -26
  141. package/ezuikit_static/v6/v2/js/jsPluginV2-2.0.1.min.js +0 -5325
  142. package/ezuikit_static/v6/v2/js/playctrl/AudioRenderer.js +0 -225
  143. package/ezuikit_static/v6/v2/js/playctrl/DecodeWorker.js +0 -711
  144. package/ezuikit_static/v6/v2/js/playctrl/Decoder.js +0 -1
  145. package/ezuikit_static/v6/v2/js/playctrl/JSPlaySDKInterface.js +0 -2518
  146. package/ezuikit_static/v6/v2/js/playctrl/SuperRender_10.js +0 -395
  147. package/ezuikit_static/v6/v2/js/playctrl/SuperRender_20.js +0 -1
  148. package/ezuikit_static/v6/v2/js/transform/SystemTransform.js +0 -22
  149. package/ezuikit_static/v6/v2/js/transform/SystemTransform.js.mem +0 -0
  150. package/ezuikit_static/v6/v2/js/transform/systemTransform-worker.min.js +0 -1
  151. package/ezuikit_static/v6/v2/js/tts-v4.js +0 -343
  152. package/ezuikit_static/v6/v2/jsPlugin-2.0.1.min.js +0 -5319
  153. package/ezuikit_static/v6/v2/rec/datepicker.js +0 -1522
  154. package/ezuikit_static/v6/v2/rec/datepicker.min.css +0 -27
  155. package/ezuikit_static/v6/v2/rec/datepicker.zh-CN.js +0 -19
  156. package/ezuikit_static/v6/v2/rec/jquery.min.js +0 -2
  157. package/ezuikit_static/v6/v2/talk/adapeter.js +0 -5497
  158. package/ezuikit_static/v6/v2/talk/janus.js +0 -3507
  159. package/ezuikit_static/v6/v2/talk/tts-v4.js +0 -343
@@ -1,67 +0,0 @@
1
- const http = require('http')
2
- const url = require('url')
3
- const fs = require('fs')
4
- const path = require('path')
5
- // const mime = require('mime')
6
-
7
- const mime = {
8
- map: {
9
- 'html': 'text/html',
10
- 'xhtml': 'application/xhtml+xml',
11
- 'xml': 'text/xml',
12
- 'js': 'application/javascript',
13
- 'wasm': 'application/wasm',
14
- 'map': 'magnus-internal/imagemap',
15
- 'css': 'text/css',
16
- 'png': 'image/png',
17
- 'jpg': 'image/jpeg',
18
- 'jpeg': 'image/jpeg',
19
- 'gif': 'image/gif',
20
- 'ico': 'image/vnd.microsoft.icon'
21
- },
22
- getType: function (ext) {
23
- let conType = this.map[ext]
24
- return conType || 'text/plain'
25
- }
26
- }
27
-
28
- const httpServer = http.createServer()
29
-
30
- httpServer.on('request', (req, res) => {
31
- console.log(`[receive request] ${req.method} ${req.url}`)
32
-
33
- const urlJson = url.parse(req.url)
34
- let { pathname } = urlJson
35
- let ext = pathname.split('.').pop()
36
- // all
37
- // res.setHeader('Cross-Origin-Embedder-Policy', 'require-corp')
38
- // res.setHeader('Cross-Origin-Opener-Policy', 'same-origin')
39
- // just page file
40
- if (ext === 'html' || ext === 'xhtml'|| ext === 'js') {
41
- //跨域隔离
42
- res.setHeader('Cross-Origin-Embedder-Policy', 'require-corp')
43
- res.setHeader('Cross-Origin-Opener-Policy', 'same-origin')
44
- res.setHeader('Access-Control-Allow-Origin', 'https://resource.eziot.com')
45
- //影响报告
46
- //res.setHeader('Cross-Origin-Embedder-Policy-Report-Only', 'require-corp')
47
- //res.setHeader('Cross-Origin-Opener-Policy-Report-Only', 'same-origin')
48
- }
49
-
50
- let contentType = mime.getType(ext)
51
- res.setHeader('Content-Type', contentType)
52
-
53
- fs.readFile(path.resolve(__dirname, pathname.substr(1)), (err, data) => {
54
- if (err) {
55
- res.writeHead(404)
56
- res.end('Not found.')
57
- } else {
58
- res.writeHead(200)
59
- res.end(data)
60
- }
61
- })
62
- })
63
-
64
- const PORT = 9091
65
- httpServer.listen(9091, () => {
66
- console.log(`Server running at http://localhost:${PORT}`)
67
- })
@@ -1,101 +0,0 @@
1
- 'use strict';
2
-
3
- const fs = require('fs');
4
- const path = require('path');
5
- const paths = require('./paths');
6
-
7
- // Make sure that including paths.js after env.js will read .env variables.
8
- delete require.cache[require.resolve('./paths')];
9
-
10
- const NODE_ENV = process.env.NODE_ENV;
11
- if (!NODE_ENV) {
12
- throw new Error(
13
- 'The NODE_ENV environment variable is required but was not specified.'
14
- );
15
- }
16
-
17
- // https://github.com/bkeepers/dotenv#what-other-env-files-can-i-use
18
- const dotenvFiles = [
19
- `${paths.dotenv}.${NODE_ENV}.local`,
20
- `${paths.dotenv}.${NODE_ENV}`,
21
- // Don't include `.env.local` for `test` environment
22
- // since normally you expect tests to produce the same
23
- // results for everyone
24
- NODE_ENV !== 'test' && `${paths.dotenv}.local`,
25
- paths.dotenv,
26
- ].filter(Boolean);
27
-
28
- // Load environment variables from .env* files. Suppress warnings using silent
29
- // if this file is missing. dotenv will never modify any environment variables
30
- // that have already been set. Variable expansion is supported in .env files.
31
- // https://github.com/motdotla/dotenv
32
- // https://github.com/motdotla/dotenv-expand
33
- dotenvFiles.forEach(dotenvFile => {
34
- if (fs.existsSync(dotenvFile)) {
35
- require('dotenv-expand')(
36
- require('dotenv').config({
37
- path: dotenvFile,
38
- })
39
- );
40
- }
41
- });
42
-
43
- // We support resolving modules according to `NODE_PATH`.
44
- // This lets you use absolute paths in imports inside large monorepos:
45
- // https://github.com/facebook/create-react-app/issues/253.
46
- // It works similar to `NODE_PATH` in Node itself:
47
- // https://nodejs.org/api/modules.html#modules_loading_from_the_global_folders
48
- // Note that unlike in Node, only *relative* paths from `NODE_PATH` are honored.
49
- // Otherwise, we risk importing Node.js core modules into an app instead of webpack shims.
50
- // https://github.com/facebook/create-react-app/issues/1023#issuecomment-265344421
51
- // We also resolve them to make sure all tools using them work consistently.
52
- const appDirectory = fs.realpathSync(process.cwd());
53
- process.env.NODE_PATH = (process.env.NODE_PATH || '')
54
- .split(path.delimiter)
55
- .filter(folder => folder && !path.isAbsolute(folder))
56
- .map(folder => path.resolve(appDirectory, folder))
57
- .join(path.delimiter);
58
-
59
- // Grab NODE_ENV and REACT_APP_* environment variables and prepare them to be
60
- // injected into the application via DefinePlugin in webpack configuration.
61
- const REACT_APP = /^REACT_APP_/i;
62
-
63
- function getClientEnvironment(publicUrl) {
64
- const raw = Object.keys(process.env)
65
- .filter(key => REACT_APP.test(key))
66
- .reduce(
67
- (env, key) => {
68
- env[key] = process.env[key];
69
- return env;
70
- },
71
- {
72
- // Useful for determining whether we’re running in production mode.
73
- // Most importantly, it switches React into the correct mode.
74
- NODE_ENV: process.env.NODE_ENV || 'development',
75
- // Useful for resolving the correct path to static assets in `public`.
76
- // For example, <img src={process.env.PUBLIC_URL + '/img/logo.png'} />.
77
- // This should only be used as an escape hatch. Normally you would put
78
- // images into the `src` and `import` them in code to get their paths.
79
- PUBLIC_URL: publicUrl,
80
- // We support configuring the sockjs pathname during development.
81
- // These settings let a developer run multiple simultaneous projects.
82
- // They are used as the connection `hostname`, `pathname` and `port`
83
- // in webpackHotDevClient. They are used as the `sockHost`, `sockPath`
84
- // and `sockPort` options in webpack-dev-server.
85
- WDS_SOCKET_HOST: process.env.WDS_SOCKET_HOST,
86
- WDS_SOCKET_PATH: process.env.WDS_SOCKET_PATH,
87
- WDS_SOCKET_PORT: process.env.WDS_SOCKET_PORT,
88
- }
89
- );
90
- // Stringify all values so we can feed into webpack DefinePlugin
91
- const stringified = {
92
- 'process.env': Object.keys(raw).reduce((env, key) => {
93
- env[key] = JSON.stringify(raw[key]);
94
- return env;
95
- }, {}),
96
- };
97
-
98
- return { raw, stringified };
99
- }
100
-
101
- module.exports = getClientEnvironment;
@@ -1,66 +0,0 @@
1
- 'use strict';
2
-
3
- const fs = require('fs');
4
- const path = require('path');
5
- const crypto = require('crypto');
6
- const chalk = require('react-dev-utils/chalk');
7
- const paths = require('./paths');
8
-
9
- // Ensure the certificate and key provided are valid and if not
10
- // throw an easy to debug error
11
- function validateKeyAndCerts({ cert, key, keyFile, crtFile }) {
12
- let encrypted;
13
- try {
14
- // publicEncrypt will throw an error with an invalid cert
15
- encrypted = crypto.publicEncrypt(cert, Buffer.from('test'));
16
- } catch (err) {
17
- throw new Error(
18
- `The certificate "${chalk.yellow(crtFile)}" is invalid.\n${err.message}`
19
- );
20
- }
21
-
22
- try {
23
- // privateDecrypt will throw an error with an invalid key
24
- crypto.privateDecrypt(key, encrypted);
25
- } catch (err) {
26
- throw new Error(
27
- `The certificate key "${chalk.yellow(keyFile)}" is invalid.\n${
28
- err.message
29
- }`
30
- );
31
- }
32
- }
33
-
34
- // Read file and throw an error if it doesn't exist
35
- function readEnvFile(file, type) {
36
- if (!fs.existsSync(file)) {
37
- throw new Error(
38
- `You specified ${chalk.cyan(
39
- type
40
- )} in your env, but the file "${chalk.yellow(file)}" can't be found.`
41
- );
42
- }
43
- return fs.readFileSync(file);
44
- }
45
-
46
- // Get the https config
47
- // Return cert files if provided in env, otherwise just true or false
48
- function getHttpsConfig() {
49
- const { SSL_CRT_FILE, SSL_KEY_FILE, HTTPS } = process.env;
50
- const isHttps = HTTPS === 'true';
51
-
52
- if (isHttps && SSL_CRT_FILE && SSL_KEY_FILE) {
53
- const crtFile = path.resolve(paths.appPath, SSL_CRT_FILE);
54
- const keyFile = path.resolve(paths.appPath, SSL_KEY_FILE);
55
- const config = {
56
- cert: readEnvFile(crtFile, 'SSL_CRT_FILE'),
57
- key: readEnvFile(keyFile, 'SSL_KEY_FILE'),
58
- };
59
-
60
- validateKeyAndCerts({ ...config, keyFile, crtFile });
61
- return config;
62
- }
63
- return isHttps;
64
- }
65
-
66
- module.exports = getHttpsConfig;
@@ -1,14 +0,0 @@
1
- 'use strict';
2
-
3
- // This is a custom Jest transformer turning style imports into empty objects.
4
- // http://facebook.github.io/jest/docs/en/webpack.html
5
-
6
- module.exports = {
7
- process() {
8
- return 'module.exports = {};';
9
- },
10
- getCacheKey() {
11
- // The output is always the same.
12
- return 'cssTransform';
13
- },
14
- };
@@ -1,40 +0,0 @@
1
- 'use strict';
2
-
3
- const path = require('path');
4
- const camelcase = require('camelcase');
5
-
6
- // This is a custom Jest transformer turning file imports into filenames.
7
- // http://facebook.github.io/jest/docs/en/webpack.html
8
-
9
- module.exports = {
10
- process(src, filename) {
11
- const assetFilename = JSON.stringify(path.basename(filename));
12
-
13
- if (filename.match(/\.svg$/)) {
14
- // Based on how SVGR generates a component name:
15
- // https://github.com/smooth-code/svgr/blob/01b194cf967347d43d4cbe6b434404731b87cf27/packages/core/src/state.js#L6
16
- const pascalCaseFilename = camelcase(path.parse(filename).name, {
17
- pascalCase: true,
18
- });
19
- const componentName = `Svg${pascalCaseFilename}`;
20
- return `const React = require('react');
21
- module.exports = {
22
- __esModule: true,
23
- default: ${assetFilename},
24
- ReactComponent: React.forwardRef(function ${componentName}(props, ref) {
25
- return {
26
- $$typeof: Symbol.for('react.element'),
27
- type: 'svg',
28
- ref: ref,
29
- key: null,
30
- props: Object.assign({}, props, {
31
- children: ${assetFilename}
32
- })
33
- };
34
- }),
35
- };`;
36
- }
37
-
38
- return `module.exports = ${assetFilename};`;
39
- },
40
- };
@@ -1,141 +0,0 @@
1
- 'use strict';
2
-
3
- const fs = require('fs');
4
- const path = require('path');
5
- const paths = require('./paths');
6
- const chalk = require('react-dev-utils/chalk');
7
- const resolve = require('resolve');
8
-
9
- /**
10
- * Get additional module paths based on the baseUrl of a compilerOptions object.
11
- *
12
- * @param {Object} options
13
- */
14
- function getAdditionalModulePaths(options = {}) {
15
- const baseUrl = options.baseUrl;
16
-
17
- // We need to explicitly check for null and undefined (and not a falsy value) because
18
- // TypeScript treats an empty string as `.`.
19
- if (baseUrl == null) {
20
- // If there's no baseUrl set we respect NODE_PATH
21
- // Note that NODE_PATH is deprecated and will be removed
22
- // in the next major release of create-react-app.
23
-
24
- const nodePath = process.env.NODE_PATH || '';
25
- return nodePath.split(path.delimiter).filter(Boolean);
26
- }
27
-
28
- const baseUrlResolved = path.resolve(paths.appPath, baseUrl);
29
-
30
- // We don't need to do anything if `baseUrl` is set to `node_modules`. This is
31
- // the default behavior.
32
- if (path.relative(paths.appNodeModules, baseUrlResolved) === '') {
33
- return null;
34
- }
35
-
36
- // Allow the user set the `baseUrl` to `appSrc`.
37
- if (path.relative(paths.appSrc, baseUrlResolved) === '') {
38
- return [paths.appSrc];
39
- }
40
-
41
- // If the path is equal to the root directory we ignore it here.
42
- // We don't want to allow importing from the root directly as source files are
43
- // not transpiled outside of `src`. We do allow importing them with the
44
- // absolute path (e.g. `src/Components/Button.js`) but we set that up with
45
- // an alias.
46
- if (path.relative(paths.appPath, baseUrlResolved) === '') {
47
- return null;
48
- }
49
-
50
- // Otherwise, throw an error.
51
- throw new Error(
52
- chalk.red.bold(
53
- "Your project's `baseUrl` can only be set to `src` or `node_modules`." +
54
- ' Create React App does not support other values at this time.'
55
- )
56
- );
57
- }
58
-
59
- /**
60
- * Get webpack aliases based on the baseUrl of a compilerOptions object.
61
- *
62
- * @param {*} options
63
- */
64
- function getWebpackAliases(options = {}) {
65
- const baseUrl = options.baseUrl;
66
-
67
- if (!baseUrl) {
68
- return {};
69
- }
70
-
71
- const baseUrlResolved = path.resolve(paths.appPath, baseUrl);
72
-
73
- if (path.relative(paths.appPath, baseUrlResolved) === '') {
74
- return {
75
- src: paths.appSrc,
76
- };
77
- }
78
- }
79
-
80
- /**
81
- * Get jest aliases based on the baseUrl of a compilerOptions object.
82
- *
83
- * @param {*} options
84
- */
85
- function getJestAliases(options = {}) {
86
- const baseUrl = options.baseUrl;
87
-
88
- if (!baseUrl) {
89
- return {};
90
- }
91
-
92
- const baseUrlResolved = path.resolve(paths.appPath, baseUrl);
93
-
94
- if (path.relative(paths.appPath, baseUrlResolved) === '') {
95
- return {
96
- '^src/(.*)$': '<rootDir>/src/$1',
97
- };
98
- }
99
- }
100
-
101
- function getModules() {
102
- // Check if TypeScript is setup
103
- const hasTsConfig = fs.existsSync(paths.appTsConfig);
104
- const hasJsConfig = fs.existsSync(paths.appJsConfig);
105
-
106
- if (hasTsConfig && hasJsConfig) {
107
- throw new Error(
108
- 'You have both a tsconfig.json and a jsconfig.json. If you are using TypeScript please remove your jsconfig.json file.'
109
- );
110
- }
111
-
112
- let config;
113
-
114
- // If there's a tsconfig.json we assume it's a
115
- // TypeScript project and set up the config
116
- // based on tsconfig.json
117
- if (hasTsConfig) {
118
- const ts = require(resolve.sync('typescript', {
119
- basedir: paths.appNodeModules,
120
- }));
121
- config = ts.readConfigFile(paths.appTsConfig, ts.sys.readFile).config;
122
- // Otherwise we'll check if there is jsconfig.json
123
- // for non TS projects.
124
- } else if (hasJsConfig) {
125
- config = require(paths.appJsConfig);
126
- }
127
-
128
- config = config || {};
129
- const options = config.compilerOptions || {};
130
-
131
- const additionalModulePaths = getAdditionalModulePaths(options);
132
-
133
- return {
134
- additionalModulePaths: additionalModulePaths,
135
- webpackAliases: getWebpackAliases(options),
136
- jestAliases: getJestAliases(options),
137
- hasTsConfig,
138
- };
139
- }
140
-
141
- module.exports = getModules();
@@ -1,72 +0,0 @@
1
- 'use strict';
2
-
3
- const path = require('path');
4
- const fs = require('fs');
5
- const getPublicUrlOrPath = require('react-dev-utils/getPublicUrlOrPath');
6
-
7
- // Make sure any symlinks in the project folder are resolved:
8
- // https://github.com/facebook/create-react-app/issues/637
9
- const appDirectory = fs.realpathSync(process.cwd());
10
- const resolveApp = relativePath => path.resolve(appDirectory, relativePath);
11
-
12
- // We use `PUBLIC_URL` environment variable or "homepage" field to infer
13
- // "public path" at which the app is served.
14
- // webpack needs to know it to put the right <script> hrefs into HTML even in
15
- // single-page apps that may serve index.html for nested URLs like /todos/42.
16
- // We can't use a relative path in HTML because we don't want to load something
17
- // like /todos/42/static/js/bundle.7289d.js. We have to know the root.
18
- const publicUrlOrPath = getPublicUrlOrPath(
19
- process.env.NODE_ENV === 'development',
20
- require(resolveApp('package.json')).homepage,
21
- process.env.PUBLIC_URL
22
- );
23
-
24
- const moduleFileExtensions = [
25
- 'web.mjs',
26
- 'mjs',
27
- 'web.js',
28
- 'js',
29
- 'web.ts',
30
- 'ts',
31
- 'web.tsx',
32
- 'tsx',
33
- 'json',
34
- 'web.jsx',
35
- 'jsx',
36
- ];
37
-
38
- // Resolve file paths in the same order as webpack
39
- const resolveModule = (resolveFn, filePath) => {
40
- const extension = moduleFileExtensions.find(extension =>
41
- fs.existsSync(resolveFn(`${filePath}.${extension}`))
42
- );
43
-
44
- if (extension) {
45
- return resolveFn(`${filePath}.${extension}`);
46
- }
47
-
48
- return resolveFn(`${filePath}.js`);
49
- };
50
-
51
- // config after eject: we're in ./config/
52
- module.exports = {
53
- dotenv: resolveApp('.env'),
54
- appPath: resolveApp('.'),
55
- appBuild: resolveApp('build'),
56
- appPublic: resolveApp('public'),
57
- appHtml: resolveApp('public/index.html'),
58
- appIndexJs: resolveModule(resolveApp, 'src/index'),
59
- appPackageJson: resolveApp('package.json'),
60
- appSrc: resolveApp('src'),
61
- appTsConfig: resolveApp('tsconfig.json'),
62
- appJsConfig: resolveApp('jsconfig.json'),
63
- yarnLockFile: resolveApp('yarn.lock'),
64
- testsSetup: resolveModule(resolveApp, 'src/setupTests'),
65
- proxySetup: resolveApp('src/setupProxy.js'),
66
- appNodeModules: resolveApp('node_modules'),
67
- publicUrlOrPath,
68
- };
69
-
70
-
71
-
72
- module.exports.moduleFileExtensions = moduleFileExtensions;
@@ -1,35 +0,0 @@
1
- 'use strict';
2
-
3
- const { resolveModuleName } = require('ts-pnp');
4
-
5
- exports.resolveModuleName = (
6
- typescript,
7
- moduleName,
8
- containingFile,
9
- compilerOptions,
10
- resolutionHost
11
- ) => {
12
- return resolveModuleName(
13
- moduleName,
14
- containingFile,
15
- compilerOptions,
16
- resolutionHost,
17
- typescript.resolveModuleName
18
- );
19
- };
20
-
21
- exports.resolveTypeReferenceDirective = (
22
- typescript,
23
- moduleName,
24
- containingFile,
25
- compilerOptions,
26
- resolutionHost
27
- ) => {
28
- return resolveModuleName(
29
- moduleName,
30
- containingFile,
31
- compilerOptions,
32
- resolutionHost,
33
- typescript.resolveTypeReferenceDirective
34
- );
35
- };