@zohodesk/react-cli 1.1.4 → 1.1.5-exp.1

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 (123) hide show
  1. package/.eslintignore +7 -7
  2. package/.eslintrc.js +180 -180
  3. package/.prettierrc +6 -6
  4. package/Changelog.md +1019 -1019
  5. package/README.md +1228 -1222
  6. package/bin/cli.js +497 -497
  7. package/docs/ComposeMinification.md +13 -13
  8. package/docs/CustomChunks.md +26 -26
  9. package/docs/DevServerPort.md +39 -39
  10. package/docs/DevStart.md +18 -18
  11. package/docs/HoverActive.md +12 -12
  12. package/docs/InstallNode.md +28 -28
  13. package/docs/ReactLive.md +13 -13
  14. package/docs/SelectorWeight.md +8 -8
  15. package/docs/TODOS.md +10 -10
  16. package/docs/ValueReplacer.md +60 -60
  17. package/docs/VariableConversion.md +729 -729
  18. package/docs/patternFiltering.md +56 -56
  19. package/docs/warnings_while_install.txt +35 -35
  20. package/files/eslintrc.js +62 -62
  21. package/files/prettierrc.js +3 -3
  22. package/lib/common/splitChunks.js +24 -7
  23. package/lib/configs/webpack.css.umd.config.js +4 -4
  24. package/lib/loaderUtils/configsAssetsLoaders.js +33 -33
  25. package/lib/loaderUtils/getCSSLoaders.js +54 -51
  26. package/lib/loaders/composeLoader.js +140 -14
  27. package/lib/loaders/workerLoader.js +9 -9
  28. package/lib/pluginUtils/getDevPlugins.js +5 -5
  29. package/lib/pluginUtils/getProdPlugins.js +5 -5
  30. package/lib/plugins/CustomAttributePlugin.md +35 -35
  31. package/lib/plugins/EFCPlugin.md +6 -6
  32. package/lib/plugins/I18NInjectIntoIndexPlugin.js +4 -4
  33. package/lib/plugins/I18nSplitPlugin/I18nDownlodLogic.js +38 -38
  34. package/lib/plugins/I18nSplitPlugin/I18nFilesEmitter.js +30 -30
  35. package/lib/plugins/I18nSplitPlugin/I18nKeysIdentifer.js +8 -8
  36. package/lib/plugins/I18nSplitPlugin/I18nSplit.md +95 -95
  37. package/lib/plugins/I18nSplitPlugin/README.md +25 -25
  38. package/lib/plugins/I18nSplitPlugin/index.js +57 -57
  39. package/lib/plugins/ResourceHintsPlugin.js +17 -17
  40. package/lib/plugins/RtlSplitPlugin/RtlCssPlugin.js +6 -6
  41. package/lib/plugins/RtlSplitPlugin/RtrSplit.md +30 -30
  42. package/lib/plugins/SelectorPlugin.js +29 -29
  43. package/lib/plugins/ServiceWorkerPlugin.js +9 -9
  44. package/lib/plugins/TPHashMappingPlugin.js +4 -4
  45. package/lib/plugins/VariableConversionCollector.js +59 -59
  46. package/lib/plugins/utils/fileHandling.js +4 -4
  47. package/lib/plugins/variableConvertorUtils.js +9 -9
  48. package/lib/postcss-plugins/RTLSplitPlugin.js +10 -10
  49. package/lib/postcss-plugins/__test__/test1Input.css +38 -38
  50. package/lib/postcss-plugins/__test__/test1Output.css +38 -38
  51. package/lib/postcss-plugins/hoverActivePlugin.js +3 -3
  52. package/lib/schemas/index.js +4 -0
  53. package/lib/sh/pre-commit.sh +34 -34
  54. package/lib/sh/reportPublish.sh +45 -45
  55. package/lib/utils/buildstats.html +148 -148
  56. package/lib/utils/cssClassNameGenerate.js +13 -13
  57. package/lib/utils/resultSchema.json +73 -73
  58. package/lib/utils/variableConverter.js +26 -11
  59. package/npm-shrinkwrap.json +14412 -14412
  60. package/npm8.md +9 -9
  61. package/package.json +122 -122
  62. package/postpublish.js +8 -8
  63. package/result.json +1 -0
  64. package/templates/app/.eslintrc.js +140 -140
  65. package/templates/app/README.md +12 -12
  66. package/templates/app/app/index.html +24 -24
  67. package/templates/app/app/properties/ApplicationResources_en_US.properties +1 -1
  68. package/templates/app/app/properties/i18nkeys.json +3 -3
  69. package/templates/app/docs/all.html +69 -69
  70. package/templates/app/mockapi/index.js +18 -18
  71. package/templates/app/package.json +37 -37
  72. package/templates/app/src/actions/SampleActions/index.js +37 -37
  73. package/templates/app/src/actions/index.js +65 -65
  74. package/templates/app/src/appUrls.js +19 -19
  75. package/templates/app/src/components/Alert/Alert.js +134 -134
  76. package/templates/app/src/components/Alert/Alert.module.css +79 -79
  77. package/templates/app/src/components/FreezeLayer/FreezeLayer.css +37 -37
  78. package/templates/app/src/components/FreezeLayer/FreezeLayer.js +84 -84
  79. package/templates/app/src/components/Sample/Sample.module.css +11 -11
  80. package/templates/app/src/components/Sample/SampleList.js +61 -61
  81. package/templates/app/src/components/Slider/Slider.css +41 -41
  82. package/templates/app/src/components/Slider/Slider.js +55 -55
  83. package/templates/app/src/containers/AlertContainer/index.js +15 -15
  84. package/templates/app/src/containers/AppContainer/index.js +96 -96
  85. package/templates/app/src/containers/AppContainer/index.module.css +27 -27
  86. package/templates/app/src/containers/CustomMatch/index.js +65 -65
  87. package/templates/app/src/containers/DevTools/index.js +10 -10
  88. package/templates/app/src/containers/Header/index.js +67 -67
  89. package/templates/app/src/containers/Header/index.module.css +43 -43
  90. package/templates/app/src/containers/Redirect/index.js +63 -63
  91. package/templates/app/src/containers/Redirector/index.js +47 -47
  92. package/templates/app/src/containers/SampleListContainer/ListContainer.js +42 -42
  93. package/templates/app/src/containers/SampleListContainer/ListContainer.module.css +3 -3
  94. package/templates/app/src/historyChange.js +5 -5
  95. package/templates/app/src/index.html +10 -10
  96. package/templates/app/src/index.js +24 -24
  97. package/templates/app/src/middleware/PromiseMiddleware.js +59 -59
  98. package/templates/app/src/reducers/alertData.js +11 -11
  99. package/templates/app/src/reducers/index.js +6 -6
  100. package/templates/app/src/reducers/samples.js +19 -19
  101. package/templates/app/src/store/configureStore.dev.js +51 -51
  102. package/templates/app/src/store/configureStore.js +5 -5
  103. package/templates/app/src/store/configureStore.prod.js +26 -26
  104. package/templates/app/src/util/Common.js +5 -5
  105. package/templates/app/src/util/RequestAPI.js +132 -132
  106. package/templates/docs/all.html +249 -249
  107. package/templates/docs/component.html +178 -178
  108. package/templates/docs/components.html +221 -221
  109. package/templates/docs/css/b.min.css +6 -6
  110. package/templates/docs/css/component.css +42 -42
  111. package/templates/docs/css/componentTest.css +6 -6
  112. package/templates/docs/css/hopscotch.css +585 -585
  113. package/templates/docs/css/style.css +1022 -1022
  114. package/templates/docs/impactReportTemplate.html +154 -154
  115. package/templates/docs/index.html +1501 -1501
  116. package/templates/docs/js/active-line.js +72 -72
  117. package/templates/docs/js/b.min.js +7 -7
  118. package/templates/docs/js/codemirror.js +9680 -9680
  119. package/templates/docs/js/designTokens.js +334 -334
  120. package/templates/docs/js/j.min.js +4 -4
  121. package/templates/docs/js/javascript.js +874 -874
  122. package/templates/docs/js/matchbrackets.js +145 -145
  123. package/unittest/index.html +37 -0
@@ -1,57 +1,57 @@
1
- # Pattern filtering
2
-
3
- As replacement for exclude we now have patterns in place of exclude to include or exclude a file based on its name in package.json.
4
-
5
-
6
- # Example for patterns :
7
-
8
- **Old System** :
9
- To exclude `node_modules` folder from convertion for the `cssVariableReplacement` plugin, we used to have :
10
-
11
- `react-cli > app > exclude > cssVariableReplacement` as ['node_modules'] in `package.json`
12
-
13
- Example :
14
-
15
- "exclude": {
16
- "cssVariableReplacement": [
17
- "node_modules"
18
- ]
19
- },
20
-
21
- **New System** :
22
-
23
- To include all files for convertion for the `valueReplacer` plugin, we now have :
24
-
25
- `react-cli > app > patterns > valueReplacer` as ['*'] in `package.json`
26
-
27
- To include `src` files for convertion for the `cssVariableReplacement` plugin, we now have :
28
-
29
- `react-cli > app > patterns > hoverActive` as ['src'] in `package.json`
30
-
31
- To exclude `node_modules` files for convertion for the `hoverActive` plugin, we now have :
32
-
33
- `react-cli > app > patterns > cssVariableReplacement` as ['!node_modules'] in `package.json`
34
- Here the `!` denotes that the folder structure/file is not to be converted.
35
-
36
- Example :
37
-
38
- "patterns": {
39
- "valueReplacer": [
40
- "*"
41
- ],
42
- "hoverActive": [
43
- "src"
44
- ],
45
- "cssVariableReplacement": [
46
- "!node_modules"
47
- ],
48
- },
49
-
50
- Note :
51
- `patterns` also added support for cssUniqueness to be applied to selective files.
52
-
53
- "patterns" : {
54
- "cssUniqueness": [
55
- "*"
56
- ],
1
+ # Pattern filtering
2
+
3
+ As replacement for exclude we now have patterns in place of exclude to include or exclude a file based on its name in package.json.
4
+
5
+
6
+ # Example for patterns :
7
+
8
+ **Old System** :
9
+ To exclude `node_modules` folder from convertion for the `cssVariableReplacement` plugin, we used to have :
10
+
11
+ `react-cli > app > exclude > cssVariableReplacement` as ['node_modules'] in `package.json`
12
+
13
+ Example :
14
+
15
+ "exclude": {
16
+ "cssVariableReplacement": [
17
+ "node_modules"
18
+ ]
19
+ },
20
+
21
+ **New System** :
22
+
23
+ To include all files for convertion for the `valueReplacer` plugin, we now have :
24
+
25
+ `react-cli > app > patterns > valueReplacer` as ['*'] in `package.json`
26
+
27
+ To include `src` files for convertion for the `cssVariableReplacement` plugin, we now have :
28
+
29
+ `react-cli > app > patterns > hoverActive` as ['src'] in `package.json`
30
+
31
+ To exclude `node_modules` files for convertion for the `hoverActive` plugin, we now have :
32
+
33
+ `react-cli > app > patterns > cssVariableReplacement` as ['!node_modules'] in `package.json`
34
+ Here the `!` denotes that the folder structure/file is not to be converted.
35
+
36
+ Example :
37
+
38
+ "patterns": {
39
+ "valueReplacer": [
40
+ "*"
41
+ ],
42
+ "hoverActive": [
43
+ "src"
44
+ ],
45
+ "cssVariableReplacement": [
46
+ "!node_modules"
47
+ ],
48
+ },
49
+
50
+ Note :
51
+ `patterns` also added support for cssUniqueness to be applied to selective files.
52
+
53
+ "patterns" : {
54
+ "cssUniqueness": [
55
+ "*"
56
+ ],
57
57
  }
@@ -1,35 +1,35 @@
1
- npm WARN deprecated babel-eslint@10.1.0: babel-eslint is now @babel/eslint-parser. This package will no longer receive updates.
2
- npm WARN deprecated eslint-loader@4.0.2: This loader has been deprecated. Please use eslint-webpack-plugin
3
- npm WARN deprecated gitlab@14.2.2: The gitlab package has found a new home in the @gitbeaker organization. For the latest gitlab node library, check out @gitbeaker/node. A full list of the features can be found here: https://github.com/jdalrymple/gitbeaker#readme
4
- npm WARN deprecated chokidar@2.1.8: Chokidar 2 will break on node v14+. Upgrade to chokidar 3 with 15x less dependencies.
5
- npm WARN deprecated fsevents@1.2.13: fsevents 1 will break on node v14+ and could be using insecure binaries. Upgrade to fsevents 2.
6
- npm WARN deprecated webdriverio@4.14.4: outdated version, please use @next
7
- npm WARN deprecated mkdirp@0.3.5: Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)
8
- npm WARN deprecated cross-spawn-async@1.0.1: cross-spawn no longer requires a build toolchain, use it instead
9
- npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142
10
- npm WARN deprecated core-js@2.6.12: core-js@<3.3 is no longer maintained and not recommended for usage due to the number of issues. Because of the V8 engine whims, feature detection in old core-js versions could cause a slowdown up to 100x even if nothing is polyfilled. Please, upgrade your dependencies to the actual version of core-js.
11
- npm WARN deprecated har-validator@5.1.5: this library is no longer supported
12
- npm WARN deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.
13
- npm WARN deprecated querystring@0.2.0: The querystring API is considered Legacy. new code should use the URLSearchParams API instead.
14
- npm WARN deprecated sane@4.1.0: some dependency vulnerabilities fixed, support for node < 10 dropped, and newer ECMAScript syntax/features added
15
- npm WARN deprecated request-promise-native@1.0.9: request-promise-native has been deprecated because it extends the now deprecated request package, see https://github.com/request/request/issues/3142
16
- npm WARN deprecated flatten@1.0.3: flatten is deprecated in favor of utility frameworks such as lodash.
17
- npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@^1.2.7 (node_modules/chokidar/node_modules/fsevents):
18
- npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@1.2.13: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
19
- npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@^2.1.2 (node_modules/jest-haste-map/node_modules/fsevents):
20
- npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.3.2: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
21
- npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@~2.3.2 (node_modules/nodemon/node_modules/chokidar/node_modules/fsevents):
22
- npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.3.2: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
23
- npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@~2.3.2 (node_modules/watchpack/node_modules/chokidar/node_modules/fsevents):
24
- npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.3.2: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
25
- npm WARN check2@1.0.0 No description
26
- npm WARN check2@1.0.0 No repository field.
27
-
28
- + @zohodesk/react-cli@0.0.1-beta.165
29
- updated 1 package and audited 1899 packages in 51.509s
30
-
31
- 21 packages are looking for funding
32
- run `npm fund` for details
33
-
34
- found 42 vulnerabilities (2 low, 20 moderate, 8 high, 12 critical)
35
- run `npm audit fix` to fix them, or `npm audit` for details
1
+ npm WARN deprecated babel-eslint@10.1.0: babel-eslint is now @babel/eslint-parser. This package will no longer receive updates.
2
+ npm WARN deprecated eslint-loader@4.0.2: This loader has been deprecated. Please use eslint-webpack-plugin
3
+ npm WARN deprecated gitlab@14.2.2: The gitlab package has found a new home in the @gitbeaker organization. For the latest gitlab node library, check out @gitbeaker/node. A full list of the features can be found here: https://github.com/jdalrymple/gitbeaker#readme
4
+ npm WARN deprecated chokidar@2.1.8: Chokidar 2 will break on node v14+. Upgrade to chokidar 3 with 15x less dependencies.
5
+ npm WARN deprecated fsevents@1.2.13: fsevents 1 will break on node v14+ and could be using insecure binaries. Upgrade to fsevents 2.
6
+ npm WARN deprecated webdriverio@4.14.4: outdated version, please use @next
7
+ npm WARN deprecated mkdirp@0.3.5: Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)
8
+ npm WARN deprecated cross-spawn-async@1.0.1: cross-spawn no longer requires a build toolchain, use it instead
9
+ npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142
10
+ npm WARN deprecated core-js@2.6.12: core-js@<3.3 is no longer maintained and not recommended for usage due to the number of issues. Because of the V8 engine whims, feature detection in old core-js versions could cause a slowdown up to 100x even if nothing is polyfilled. Please, upgrade your dependencies to the actual version of core-js.
11
+ npm WARN deprecated har-validator@5.1.5: this library is no longer supported
12
+ npm WARN deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.
13
+ npm WARN deprecated querystring@0.2.0: The querystring API is considered Legacy. new code should use the URLSearchParams API instead.
14
+ npm WARN deprecated sane@4.1.0: some dependency vulnerabilities fixed, support for node < 10 dropped, and newer ECMAScript syntax/features added
15
+ npm WARN deprecated request-promise-native@1.0.9: request-promise-native has been deprecated because it extends the now deprecated request package, see https://github.com/request/request/issues/3142
16
+ npm WARN deprecated flatten@1.0.3: flatten is deprecated in favor of utility frameworks such as lodash.
17
+ npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@^1.2.7 (node_modules/chokidar/node_modules/fsevents):
18
+ npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@1.2.13: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
19
+ npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@^2.1.2 (node_modules/jest-haste-map/node_modules/fsevents):
20
+ npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.3.2: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
21
+ npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@~2.3.2 (node_modules/nodemon/node_modules/chokidar/node_modules/fsevents):
22
+ npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.3.2: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
23
+ npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@~2.3.2 (node_modules/watchpack/node_modules/chokidar/node_modules/fsevents):
24
+ npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.3.2: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
25
+ npm WARN check2@1.0.0 No description
26
+ npm WARN check2@1.0.0 No repository field.
27
+
28
+ + @zohodesk/react-cli@0.0.1-beta.165
29
+ updated 1 package and audited 1899 packages in 51.509s
30
+
31
+ 21 packages are looking for funding
32
+ run `npm fund` for details
33
+
34
+ found 42 vulnerabilities (2 low, 20 moderate, 8 high, 12 critical)
35
+ run `npm audit fix` to fix them, or `npm audit` for details
package/files/eslintrc.js CHANGED
@@ -1,62 +1,62 @@
1
- const [off, , error] = ['off', 'warn', 'error'];
2
-
3
- module.exports = {
4
- env: {
5
- browser: true,
6
- es2021: true,
7
- },
8
- extends: [
9
- 'plugin:react/recommended',
10
- 'plugin:react-hooks/recommended',
11
- 'airbnb',
12
- 'prettier',
13
- ],
14
- parserOptions: {
15
- ecmaFeatures: {
16
- jsx: true,
17
- },
18
- ecmaVersion: 12,
19
- sourceType: 'module',
20
- },
21
- plugins: [
22
- 'react',
23
- 'css-modules',
24
- '@zohodesk/zsecurity',
25
- '@zohodesk/react-performance',
26
- ],
27
- rules: {
28
- // Internal Rules
29
- '@zohodesk/react-performance/no-ref-mapstatetoprops': error,
30
- '@zohodesk/zsecurity/no-unsecure-html': error,
31
- '@zohodesk/zsecurity/no-protocol-check': error,
32
-
33
- // CSS Module Rules
34
- 'css-modules/no-unused-class': [error, { camelCase: true }],
35
- 'css-modules/no-undef-class': [error, { camelCase: 'only' }],
36
-
37
- 'import/no-unresolved': off,
38
- 'import/no-extraneous-dependencies': off,
39
-
40
- // As redux used
41
- 'no-shadow': off, // As we import the action files and use the same name in getting from props built from connect.
42
- 'react/jsx-filename-extension': off,
43
-
44
- // As we don't follow
45
- 'react/require-default-props': off,
46
- 'react/jsx-props-no-spreading': off,
47
-
48
- // As we didn't update
49
- 'react/jsx-fragments': off,
50
-
51
- // Not needed
52
- 'no-plusplus': off,
53
- 'no-unused-expressions': [
54
- error,
55
- {
56
- allowShortCircuit: true,
57
- allowTernary: true,
58
- },
59
- ],
60
- 'react/jsx-no-target-blank': error,
61
- },
62
- };
1
+ const [off, , error] = ['off', 'warn', 'error'];
2
+
3
+ module.exports = {
4
+ env: {
5
+ browser: true,
6
+ es2021: true,
7
+ },
8
+ extends: [
9
+ 'plugin:react/recommended',
10
+ 'plugin:react-hooks/recommended',
11
+ 'airbnb',
12
+ 'prettier',
13
+ ],
14
+ parserOptions: {
15
+ ecmaFeatures: {
16
+ jsx: true,
17
+ },
18
+ ecmaVersion: 12,
19
+ sourceType: 'module',
20
+ },
21
+ plugins: [
22
+ 'react',
23
+ 'css-modules',
24
+ '@zohodesk/zsecurity',
25
+ '@zohodesk/react-performance',
26
+ ],
27
+ rules: {
28
+ // Internal Rules
29
+ '@zohodesk/react-performance/no-ref-mapstatetoprops': error,
30
+ '@zohodesk/zsecurity/no-unsecure-html': error,
31
+ '@zohodesk/zsecurity/no-protocol-check': error,
32
+
33
+ // CSS Module Rules
34
+ 'css-modules/no-unused-class': [error, { camelCase: true }],
35
+ 'css-modules/no-undef-class': [error, { camelCase: 'only' }],
36
+
37
+ 'import/no-unresolved': off,
38
+ 'import/no-extraneous-dependencies': off,
39
+
40
+ // As redux used
41
+ 'no-shadow': off, // As we import the action files and use the same name in getting from props built from connect.
42
+ 'react/jsx-filename-extension': off,
43
+
44
+ // As we don't follow
45
+ 'react/require-default-props': off,
46
+ 'react/jsx-props-no-spreading': off,
47
+
48
+ // As we didn't update
49
+ 'react/jsx-fragments': off,
50
+
51
+ // Not needed
52
+ 'no-plusplus': off,
53
+ 'no-unused-expressions': [
54
+ error,
55
+ {
56
+ allowShortCircuit: true,
57
+ allowTernary: true,
58
+ },
59
+ ],
60
+ 'react/jsx-no-target-blank': error,
61
+ },
62
+ };
@@ -1,3 +1,3 @@
1
- module.exports = {
2
- trailingComma: 'none',
3
- };
1
+ module.exports = {
2
+ trailingComma: 'none',
3
+ };
@@ -22,15 +22,20 @@ let {
22
22
  app: {
23
23
  vendorExclude,
24
24
  customChunks,
25
- vendorInclude
25
+ vendorInclude,
26
+ effectiveChunkSplitting
26
27
  }
27
28
  } = options;
29
+ let reactBundle = ['react', 'react-dom', 'react-redux', 'react-transition-group', 'scheduler', // what is scheduler
30
+ 'prop-types', // why protypes needed
31
+ 'use-subscription' // 'what is it'
32
+ ];
28
33
 
29
34
  let isVendor = function isVendor(module) {
30
35
  let {
31
36
  userRequest
32
37
  } = module;
33
- let excludeList = ['script-loader', 'raw-loader', 'react', 'react-dom'];
38
+ let excludeList = ['script-loader', 'raw-loader', ...reactBundle];
34
39
  excludeList = [...excludeList, ...vendorExclude];
35
40
  return userRequest && (vendorInclude.some(item => userRequest.indexOf(item) !== -1) || userRequest.indexOf('node_modules') >= 0 && userRequest.endsWith('.css') === false && userRequest.endsWith('publicPathConfig.js') === false && excludeList.every(item => userRequest.indexOf(`node_modules${ps}${item}${ps}`) === -1));
36
41
  };
@@ -39,11 +44,13 @@ let isReact = module => {
39
44
  let {
40
45
  userRequest
41
46
  } = module;
42
- let reactBundle = ['react', 'react-dom'];
43
47
  return userRequest && reactBundle.some(pkg => userRequest.indexOf(`node_modules${ps}${pkg}${ps}`) >= 0);
44
48
  };
45
49
 
46
- let defaultChunks = {
50
+ let baseSplitChunkConfig = {
51
+ minSize: 12000
52
+ };
53
+ let specificCacheGroupConfig = {
47
54
  'react.vendor': {
48
55
  name: 'react.vendor',
49
56
  chunks: 'all',
@@ -116,11 +123,21 @@ customChunks.map((obj, index) => ({
116
123
 
117
124
  return customChunksConfig[name] = obj;
118
125
  });
119
- var _default = {
120
- minSize: 12000,
126
+ const isEnableChunkSplitting = effectiveChunkSplitting.enable;
127
+
128
+ if (isEnableChunkSplitting) {
129
+ const config = require(_path.default.join(process.cwd(), effectiveChunkSplitting.configFilePath));
130
+
131
+ console.log('config', config);
132
+ specificCacheGroupConfig = Object.assign(specificCacheGroupConfig, config.getAdditionalCacheGroupConfig());
133
+ baseSplitChunkConfig = Object.assign(baseSplitChunkConfig, config.getAdditionalBaseChunkSplitConfig());
134
+ }
135
+
136
+ const splitChunkConfig = { ...baseSplitChunkConfig,
121
137
  cacheGroups: Object.assign({
122
138
  default: false,
123
139
  vendors: false
124
- }, defaultChunks, customChunksConfig)
140
+ }, specificCacheGroupConfig, customChunksConfig)
125
141
  };
142
+ var _default = splitChunkConfig;
126
143
  exports.default = _default;
@@ -67,10 +67,10 @@ module.exports = {
67
67
  }],
68
68
  include: _path.default.join(appPath, 'src')
69
69
  }
70
- /*,
71
- {
72
- test: /\.css$/,
73
- use: [MiniCssExtractPlugin.loader, 'css-loader']
70
+ /*,
71
+ {
72
+ test: /\.css$/,
73
+ use: [MiniCssExtractPlugin.loader, 'css-loader']
74
74
  }*/
75
75
  , {
76
76
  test: /(\.module)?\.css$/,
@@ -79,39 +79,39 @@ function createNameTemplate(enableChunkHash) {
79
79
  const ext = `${enableChunkHash ? '.[hash:20]' : ''}.[ext]`;
80
80
  return `[name]${ext}`;
81
81
  }
82
- /*
83
- export function createImageAndFontsAndSVGLoaders(enableChunkHash) {
84
- const nameTemplate = createNameTemplate(enableChunkHash);
85
- return [
86
- configImageLoader(nameTemplate),
87
- configFontLoader(nameTemplate),
88
- configSVGLoader(nameTemplate),
89
- configAudioLoader(nameTemplate)
90
- ];
91
- }
82
+ /*
83
+ export function createImageAndFontsAndSVGLoaders(enableChunkHash) {
84
+ const nameTemplate = createNameTemplate(enableChunkHash);
85
+ return [
86
+ configImageLoader(nameTemplate),
87
+ configFontLoader(nameTemplate),
88
+ configSVGLoader(nameTemplate),
89
+ configAudioLoader(nameTemplate)
90
+ ];
91
+ }
92
92
  */
93
93
 
94
- /*
95
- export function createLoaderOptionObject(
96
- loaderName,
97
- nameTemplate,
98
- fallback,
99
- limit = 1000
100
- ) {
101
- return {
102
- loader: loaderName,
103
- options: {
104
- limit,
105
- name: nameTemplate,
106
- fallback
107
- }
108
- };
109
- }
110
-
111
- function configLoaderObject(filter, loaderAndOptions) {
112
- return {
113
- test: filter,
114
- use: loaderAndOptions
115
- };
116
- }
94
+ /*
95
+ export function createLoaderOptionObject(
96
+ loaderName,
97
+ nameTemplate,
98
+ fallback,
99
+ limit = 1000
100
+ ) {
101
+ return {
102
+ loader: loaderName,
103
+ options: {
104
+ limit,
105
+ name: nameTemplate,
106
+ fallback
107
+ }
108
+ };
109
+ }
110
+
111
+ function configLoaderObject(filter, loaderAndOptions) {
112
+ return {
113
+ test: filter,
114
+ use: loaderAndOptions
115
+ };
116
+ }
117
117
  */
@@ -62,7 +62,10 @@ const getCSSLoaders = optionsObj => {
62
62
 
63
63
  return `${prefix} ${selector}`; // Make selectors like [dir=rtl] > .selector
64
64
  }
65
- }), plugins.combinerMediaQuery && require('postcss-combine-media-query')(), plugins.hoverActive && require('../postcss-plugins/hoverActivePlugin')(mediaQueryHoverActiveString), plugins.cssVariableReplacement && fs.existsSync(cssVariableReplacementConfig) && require('../postcss-plugins/variableModificationPlugin/index').plugin(cssVariableReplacementConfig)].filter(Boolean);
65
+ }), plugins.combinerMediaQuery && require('postcss-combine-media-query')(), plugins.hoverActive && require('../postcss-plugins/hoverActivePlugin')(mediaQueryHoverActiveString), plugins.cssVariableReplacement && fs.existsSync(cssVariableReplacementConfig) && require('../postcss-plugins/variableModificationPlugin/index').plugin(cssVariableReplacementConfig) // ,
66
+ // plugins.composeMinification &&
67
+ // require('../postcss-plugins/composePlugin')()
68
+ ].filter(Boolean);
66
69
  return [cssSelectorZipPath && {
67
70
  loader: require.resolve('../loaders/selectorMappingLoader')
68
71
  }, {
@@ -86,56 +89,56 @@ const getCSSLoaders = optionsObj => {
86
89
  // console.log('check here : ', params.resourcePath);
87
90
  // getCSSLoaders for all postcss filtering
88
91
 
89
- /*
90
- input :
91
- params.resourcePath : 'D:/MyWork/..../desk_client_app/supportapp/src/components/Avatar/Avatar.module.css,
92
- patterns : [
93
- // include all files
94
- "valueReplacer": [
95
- "*"
96
- ],
97
- // include all files
98
- "selectorReplace": [
99
- "*"
100
- ],
101
- // include src folder, include deskapp folder, exclude node modules
102
- "hoverActive": [
103
- "src",
104
- "deskapp",
105
- "!node_modules"
106
- ],
107
- // include src folder, include deskapp folder, exclude node modules
108
- "combinerMediaQuery": [
109
- "src",
110
- "deskapp",
111
- "!node_modules"
112
- ],
113
- // include src folder, include deskapp folder, exclude node modules
114
- "hasRTL": [
115
- "src",
116
- "deskapp",
117
- "!node_modules"
118
- ],
119
- // include src folder, include deskapp folder, exclude node modules
120
- "cssVariableReplacement": [
121
- "src",
122
- "deskapp",
123
- "!node_modules"
124
- ],
125
- // include src folder, include deskapp folder, exclude node modules
126
- "selectorWeight": [
127
- "src",
128
- "deskapp",
129
- "!node_modules"
130
- ],
131
- // include all files
132
- "cssUniqueness": [
133
- "*"
134
- ]
135
- ],
136
-
137
- [ postcssPlugins that are implemented ]
138
- */
92
+ /*
93
+ input :
94
+ params.resourcePath : 'D:/MyWork/..../desk_client_app/supportapp/src/components/Avatar/Avatar.module.css,
95
+ patterns : [
96
+ // include all files
97
+ "valueReplacer": [
98
+ "*"
99
+ ],
100
+ // include all files
101
+ "selectorReplace": [
102
+ "*"
103
+ ],
104
+ // include src folder, include deskapp folder, exclude node modules
105
+ "hoverActive": [
106
+ "src",
107
+ "deskapp",
108
+ "!node_modules"
109
+ ],
110
+ // include src folder, include deskapp folder, exclude node modules
111
+ "combinerMediaQuery": [
112
+ "src",
113
+ "deskapp",
114
+ "!node_modules"
115
+ ],
116
+ // include src folder, include deskapp folder, exclude node modules
117
+ "hasRTL": [
118
+ "src",
119
+ "deskapp",
120
+ "!node_modules"
121
+ ],
122
+ // include src folder, include deskapp folder, exclude node modules
123
+ "cssVariableReplacement": [
124
+ "src",
125
+ "deskapp",
126
+ "!node_modules"
127
+ ],
128
+ // include src folder, include deskapp folder, exclude node modules
129
+ "selectorWeight": [
130
+ "src",
131
+ "deskapp",
132
+ "!node_modules"
133
+ ],
134
+ // include all files
135
+ "cssUniqueness": [
136
+ "*"
137
+ ]
138
+ ],
139
+
140
+ [ postcssPlugins that are implemented ]
141
+ */
139
142
  // console.log(params.resourcePath);
140
143
  // console.log(postcssPlugins);
141
144
  const finalpostcssPlugins = (0, _fileHandling.isFileNameMatchingPattern)({