@zohodesk/react-cli 1.0.2 → 1.0.3-exp.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.
- package/.eslintignore +7 -7
- package/.eslintrc.js +180 -180
- package/.prettierrc +6 -6
- package/Changelog.md +1019 -1019
- package/README.md +1209 -1165
- package/bin/cli.js +489 -483
- package/docs/ComposeMinification.md +14 -0
- package/docs/CustomChunks.md +26 -26
- package/docs/DevServerPort.md +39 -39
- package/docs/DevStart.md +18 -18
- package/docs/HoverActive.md +12 -12
- package/docs/InstallNode.md +28 -28
- package/docs/SelectorWeight.md +8 -8
- package/docs/TODOS.md +10 -10
- package/docs/ValueReplacer.md +60 -60
- package/docs/VariableConversion.md +729 -729
- package/docs/warnings_while_install.txt +35 -35
- package/files/eslintrc.js +62 -62
- package/files/prettierrc.js +3 -3
- package/lib/common/buildEs.js +12 -0
- package/lib/common/testPattern.js +0 -2
- package/lib/common/valueReplacer.js +1 -3
- package/lib/configs/resolvers.js +14 -3
- package/lib/configs/webpack.css.umd.config.js +4 -4
- package/lib/configs/webpack.dev.config.js +6 -0
- package/lib/configs/webpack.docs.config.js +4 -0
- package/lib/configs/webpack.impact.config.js +4 -0
- package/lib/configs/webpack.prod.config.js +6 -0
- package/lib/loaderUtils/configsAssetsLoaders.js +33 -33
- package/lib/loaderUtils/getCSSLoaders.js +78 -49
- package/lib/loaderUtils/tests/windowsModification.test.js +10 -0
- package/lib/loaderUtils/windowsModification.js +6 -1
- package/lib/loaders/composeLoader.js +172 -0
- package/lib/loaders/selectorMappingLoader.js +9 -9
- package/lib/loaders/workerLoader.js +9 -9
- package/lib/logger.js +20 -0
- package/lib/pluginUtils/getDevPlugins.js +23 -8
- package/lib/pluginUtils/getProdPlugins.js +20 -8
- package/lib/pluginUtils/getUMDCSSPlugins.js +1 -1
- package/lib/pluginUtils/getUMDComponentPlugins.js +1 -1
- package/lib/plugins/CustomAttributePlugin.js +82 -0
- package/lib/plugins/CustomAttributePlugin.md +35 -0
- package/lib/plugins/EFCPlugin.js +9 -9
- package/lib/plugins/EFCPlugin.md +6 -6
- package/lib/plugins/EFCTemplatePlugin.js +10 -12
- package/lib/plugins/I18NInjectIntoIndexPlugin.js +12 -13
- package/lib/plugins/I18nSplitPlugin/I18nDebugPlugin.js +2 -3
- package/lib/plugins/I18nSplitPlugin/I18nDownlodLogic.js +38 -38
- package/lib/plugins/I18nSplitPlugin/I18nFilesEmitter.js +30 -30
- package/lib/plugins/I18nSplitPlugin/I18nKeysIdentifer.js +10 -15
- package/lib/plugins/I18nSplitPlugin/I18nSplit.md +95 -95
- package/lib/plugins/I18nSplitPlugin/README.md +25 -25
- package/lib/plugins/I18nSplitPlugin/index.js +57 -57
- package/lib/plugins/I18nSplitPlugin/utils/propertiesUtils.js +8 -8
- package/lib/plugins/{UglifyCSSPlugin.js → MinifyPlugin.js} +3 -3
- package/lib/plugins/ResourceHintsPlugin.js +17 -17
- package/lib/plugins/RtlSplitPlugin/RtlCssPlugin.js +6 -6
- package/lib/plugins/RtlSplitPlugin/RtrSplit.md +30 -30
- package/lib/plugins/SelectorPlugin.js +66 -48
- package/lib/plugins/ServiceWorkerPlugin.js +9 -9
- package/lib/plugins/TPHashMappingPlugin.js +4 -4
- package/lib/plugins/VariableConversionCollector.js +94 -88
- package/lib/plugins/index.js +7 -7
- package/lib/plugins/utils/classHandling.js +20 -0
- package/lib/plugins/utils/fileHandling.js +107 -0
- package/lib/plugins/utils/tests/fileHandling.test.js +30 -0
- package/lib/postcss-plugins/EmptyPlugin.js +8 -0
- package/lib/postcss-plugins/ExcludePlugin.js +1 -1
- package/lib/postcss-plugins/IncludePlugin.js +0 -1
- package/lib/postcss-plugins/RTLSplitPlugin.js +14 -20
- package/lib/postcss-plugins/ValueReplacer.js +2 -13
- package/lib/postcss-plugins/__test__/test1Input.css +38 -38
- package/lib/postcss-plugins/__test__/test1Output.css +38 -38
- package/lib/postcss-plugins/hoverActivePlugin.js +3 -9
- package/lib/postcss-plugins/variableModificationPlugin/index.js +2 -21
- package/lib/schemas/index.js +39 -4
- package/lib/servers/devBuild.js +13 -11
- package/lib/servers/httpsOptions.js +12 -13
- package/lib/servers/nowatchserver.js +5 -3
- package/lib/servers/requireLocalOrGlobal.js +61 -0
- package/lib/servers/server.js +3 -5
- package/lib/sh/pre-commit.sh +34 -34
- package/lib/sh/reportPublish.sh +45 -45
- package/lib/utils/buildstats.html +148 -148
- package/lib/utils/cssClassNameGenerate.js +38 -12
- package/lib/utils/getOptions.js +9 -0
- package/lib/utils/resultSchema.json +73 -73
- package/lib/utils/variableConvertor.js +159 -0
- package/npm8.md +9 -9
- package/package-lock.json +14412 -0
- package/package.json +121 -120
- package/postpublish.js +8 -8
- package/templates/app/.eslintrc.js +140 -140
- package/templates/app/README.md +12 -12
- package/templates/app/app/index.html +24 -24
- package/templates/app/app/properties/ApplicationResources_en_US.properties +1 -1
- package/templates/app/app/properties/i18nkeys.json +3 -3
- package/templates/app/docs/all.html +69 -69
- package/templates/app/mockapi/index.js +18 -18
- package/templates/app/package.json +37 -37
- package/templates/app/src/actions/SampleActions/index.js +37 -37
- package/templates/app/src/actions/index.js +65 -65
- package/templates/app/src/appUrls.js +19 -19
- package/templates/app/src/components/Alert/Alert.js +134 -134
- package/templates/app/src/components/Alert/Alert.module.css +79 -79
- package/templates/app/src/components/FreezeLayer/FreezeLayer.css +37 -37
- package/templates/app/src/components/FreezeLayer/FreezeLayer.js +84 -84
- package/templates/app/src/components/Sample/Sample.module.css +11 -11
- package/templates/app/src/components/Sample/SampleList.js +61 -61
- package/templates/app/src/components/Slider/Slider.css +41 -41
- package/templates/app/src/components/Slider/Slider.js +55 -55
- package/templates/app/src/containers/AlertContainer/index.js +15 -15
- package/templates/app/src/containers/AppContainer/index.js +96 -96
- package/templates/app/src/containers/AppContainer/index.module.css +27 -27
- package/templates/app/src/containers/CustomMatch/index.js +65 -65
- package/templates/app/src/containers/DevTools/index.js +10 -10
- package/templates/app/src/containers/Header/index.js +67 -67
- package/templates/app/src/containers/Header/index.module.css +43 -43
- package/templates/app/src/containers/Redirect/index.js +63 -63
- package/templates/app/src/containers/Redirector/index.js +47 -47
- package/templates/app/src/containers/SampleListContainer/ListContainer.js +42 -42
- package/templates/app/src/containers/SampleListContainer/ListContainer.module.css +3 -3
- package/templates/app/src/historyChange.js +5 -5
- package/templates/app/src/index.html +10 -10
- package/templates/app/src/index.js +24 -24
- package/templates/app/src/middleware/PromiseMiddleware.js +59 -59
- package/templates/app/src/reducers/alertData.js +11 -11
- package/templates/app/src/reducers/index.js +6 -6
- package/templates/app/src/reducers/samples.js +19 -19
- package/templates/app/src/store/configureStore.dev.js +51 -51
- package/templates/app/src/store/configureStore.js +5 -5
- package/templates/app/src/store/configureStore.prod.js +26 -26
- package/templates/app/src/util/Common.js +5 -5
- package/templates/app/src/util/RequestAPI.js +132 -132
- package/templates/docs/all.html +249 -249
- package/templates/docs/component.html +178 -178
- package/templates/docs/components.html +221 -221
- package/templates/docs/css/b.min.css +6 -6
- package/templates/docs/css/component.css +42 -42
- package/templates/docs/css/componentTest.css +6 -6
- package/templates/docs/css/hopscotch.css +585 -585
- package/templates/docs/css/style.css +1022 -1022
- package/templates/docs/impactReportTemplate.html +154 -154
- package/templates/docs/index.html +1501 -1501
- package/templates/docs/js/active-line.js +72 -72
- package/templates/docs/js/b.min.js +7 -7
- package/templates/docs/js/codemirror.js +9680 -9680
- package/templates/docs/js/designTokens.js +334 -334
- package/templates/docs/js/j.min.js +4 -4
- package/templates/docs/js/javascript.js +874 -874
- package/templates/docs/js/matchbrackets.js +145 -145
- package/lib/plugins/composeCommonPlugin.js +0 -30
- package/lib/postcss-plugins/variableModifier.js +0 -244
- package/result.json +0 -1
- package/unittest/index.html +0 -37
|
@@ -21,23 +21,23 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
21
21
|
|
|
22
22
|
// #region initial
|
|
23
23
|
|
|
24
|
-
/**
|
|
25
|
-
* @TODO:
|
|
26
|
-
* [?] add comment line options for properties file and get all keys form property file do right way to genarate them
|
|
27
|
-
* [?] need to discuss with collectI18n Keys with js comment need to conform "what is the comment? "
|
|
24
|
+
/**
|
|
25
|
+
* @TODO:
|
|
26
|
+
* [?] add comment line options for properties file and get all keys form property file do right way to genarate them
|
|
27
|
+
* [?] need to discuss with collectI18n Keys with js comment need to conform "what is the comment? "
|
|
28
28
|
*/
|
|
29
29
|
|
|
30
|
-
/**
|
|
31
|
-
* Notes: this plugin has done below works
|
|
32
|
-
* 1. collect I18n Keys from js files and make it as Depenencies
|
|
33
|
-
* 2. we create file(asset) for chunk specific i18nChunk Files
|
|
34
|
-
* 3. create hash for the specific i18nChunk Files
|
|
35
|
-
* 4. write logic to requireEnsure method for dowlod I18n chunk download dynamicaly
|
|
36
|
-
* 5. create manifest.json file which has the mapping of chunk-locales-i18nChunkFile
|
|
37
|
-
* for the external referrece.
|
|
38
|
-
* Hints :-
|
|
39
|
-
* - file means your machine files
|
|
40
|
-
* - asset means that also file but that will create by webpack after build
|
|
30
|
+
/**
|
|
31
|
+
* Notes: this plugin has done below works
|
|
32
|
+
* 1. collect I18n Keys from js files and make it as Depenencies
|
|
33
|
+
* 2. we create file(asset) for chunk specific i18nChunk Files
|
|
34
|
+
* 3. create hash for the specific i18nChunk Files
|
|
35
|
+
* 4. write logic to requireEnsure method for dowlod I18n chunk download dynamicaly
|
|
36
|
+
* 5. create manifest.json file which has the mapping of chunk-locales-i18nChunkFile
|
|
37
|
+
* for the external referrece.
|
|
38
|
+
* Hints :-
|
|
39
|
+
* - file means your machine files
|
|
40
|
+
* - asset means that also file but that will create by webpack after build
|
|
41
41
|
*/
|
|
42
42
|
// const getI18nLocales = require('./utils/getI18nLocales');
|
|
43
43
|
// const { ConcatSource, SourceMapSource, OriginalSource } = sources;
|
|
@@ -49,16 +49,16 @@ const MODULE_TYPE = 'json/i18n';
|
|
|
49
49
|
const i18ntype = locale => `${MODULE_TYPE}/${locale}`;
|
|
50
50
|
|
|
51
51
|
const pluginName = 'i18n-plugin';
|
|
52
|
-
/**
|
|
53
|
-
* @typedef I18nPluginOptions
|
|
54
|
-
* @property {String} filenameTemplate this was template for i18n chunk
|
|
55
|
-
* @property {String} jsResource this was path for jsResource i18n file
|
|
56
|
-
* @property {String} propertiesFolder this was path for propertiesFolder i18n file
|
|
57
|
-
* @property {Boolean} disableDefault this option for disable defulat value for i18n keys, means if the language file does not have some key we don't give jsResource value
|
|
58
|
-
* @property {String} i18nManifestFileName this was ouput path for i18n manifest.
|
|
59
|
-
* @property {String} jsonpFunc this was function name, we will call that function everytime i18n chunk download.
|
|
60
|
-
* @property {String} localeVarName this was variable name, we will call that function everytime i18n chunk download.
|
|
61
|
-
*
|
|
52
|
+
/**
|
|
53
|
+
* @typedef I18nPluginOptions
|
|
54
|
+
* @property {String} filenameTemplate this was template for i18n chunk
|
|
55
|
+
* @property {String} jsResource this was path for jsResource i18n file
|
|
56
|
+
* @property {String} propertiesFolder this was path for propertiesFolder i18n file
|
|
57
|
+
* @property {Boolean} disableDefault this option for disable defulat value for i18n keys, means if the language file does not have some key we don't give jsResource value
|
|
58
|
+
* @property {String} i18nManifestFileName this was ouput path for i18n manifest.
|
|
59
|
+
* @property {String} jsonpFunc this was function name, we will call that function everytime i18n chunk download.
|
|
60
|
+
* @property {String} localeVarName this was variable name, we will call that function everytime i18n chunk download.
|
|
61
|
+
*
|
|
62
62
|
*/
|
|
63
63
|
|
|
64
64
|
class I18nPlugin {
|
|
@@ -104,13 +104,13 @@ class I18nPlugin {
|
|
|
104
104
|
}
|
|
105
105
|
|
|
106
106
|
maintainHashForAllI18nAssets(compilation) {
|
|
107
|
-
/**
|
|
108
|
-
* we write chunkHash logic inside of our plugin Because we only add Dependency not Module.
|
|
109
|
-
* So we need to update chunkHash for our assets
|
|
110
|
-
* and we not able tell with just Modules.
|
|
111
|
-
* Because, if we add Module for the Depenentcy then that module must has some hash.
|
|
112
|
-
* But our I18n Hash is no module specific it was chunk specific,
|
|
113
|
-
* that's why we do the stuf in the chunkHash hook.
|
|
107
|
+
/**
|
|
108
|
+
* we write chunkHash logic inside of our plugin Because we only add Dependency not Module.
|
|
109
|
+
* So we need to update chunkHash for our assets
|
|
110
|
+
* and we not able tell with just Modules.
|
|
111
|
+
* Because, if we add Module for the Depenentcy then that module must has some hash.
|
|
112
|
+
* But our I18n Hash is no module specific it was chunk specific,
|
|
113
|
+
* that's why we do the stuf in the chunkHash hook.
|
|
114
114
|
*/
|
|
115
115
|
compilation.hooks.chunkHash.tap(pluginName, (chunk, chunkHash) => {
|
|
116
116
|
const {
|
|
@@ -154,31 +154,31 @@ class I18nPlugin {
|
|
|
154
154
|
}
|
|
155
155
|
|
|
156
156
|
}
|
|
157
|
-
/*
|
|
158
|
-
// TODO: need to reimplement this logic
|
|
159
|
-
// NOTE: this logic for split all content hash per mani chunk
|
|
160
|
-
// like add chunk content hash to main locale i18n file
|
|
161
|
-
|
|
162
|
-
// let isEntry = chunk.name === this.options.mainChunkName;
|
|
163
|
-
// if (chunk.name === 'main' && chunk.hasEntryModule()) {
|
|
164
|
-
if (isEntry) {
|
|
165
|
-
const hashSource = new ConcatSource();
|
|
166
|
-
const dummyChunk = new chunk.constructor();
|
|
167
|
-
hashSource.add('// it wil be I18N file hash');
|
|
168
|
-
const templateHooks = compilation.chunkTemplate.hooks;
|
|
169
|
-
let c = templateHooks.render.call(
|
|
170
|
-
templateHooks.module.call(
|
|
171
|
-
hashSource,
|
|
172
|
-
dummyChunk,
|
|
173
|
-
compilation.moduleTemplate.javascript,
|
|
174
|
-
compilation.dependencyTemplates
|
|
175
|
-
),
|
|
176
|
-
dummyChunk,
|
|
177
|
-
compilation.moduleTemplate.javascript,
|
|
178
|
-
compilation.dependencyTemplates
|
|
179
|
-
);
|
|
180
|
-
|
|
181
|
-
}
|
|
157
|
+
/*
|
|
158
|
+
// TODO: need to reimplement this logic
|
|
159
|
+
// NOTE: this logic for split all content hash per mani chunk
|
|
160
|
+
// like add chunk content hash to main locale i18n file
|
|
161
|
+
|
|
162
|
+
// let isEntry = chunk.name === this.options.mainChunkName;
|
|
163
|
+
// if (chunk.name === 'main' && chunk.hasEntryModule()) {
|
|
164
|
+
if (isEntry) {
|
|
165
|
+
const hashSource = new ConcatSource();
|
|
166
|
+
const dummyChunk = new chunk.constructor();
|
|
167
|
+
hashSource.add('// it wil be I18N file hash');
|
|
168
|
+
const templateHooks = compilation.chunkTemplate.hooks;
|
|
169
|
+
let c = templateHooks.render.call(
|
|
170
|
+
templateHooks.module.call(
|
|
171
|
+
hashSource,
|
|
172
|
+
dummyChunk,
|
|
173
|
+
compilation.moduleTemplate.javascript,
|
|
174
|
+
compilation.dependencyTemplates
|
|
175
|
+
),
|
|
176
|
+
dummyChunk,
|
|
177
|
+
compilation.moduleTemplate.javascript,
|
|
178
|
+
compilation.dependencyTemplates
|
|
179
|
+
);
|
|
180
|
+
|
|
181
|
+
}
|
|
182
182
|
*/
|
|
183
183
|
|
|
184
184
|
|
|
@@ -11,6 +11,8 @@ var _fs = require("fs");
|
|
|
11
11
|
|
|
12
12
|
var _path = require("path");
|
|
13
13
|
|
|
14
|
+
var _logger = require("../../../logger");
|
|
15
|
+
|
|
14
16
|
function isComment(line) {
|
|
15
17
|
return line[0] === '#';
|
|
16
18
|
}
|
|
@@ -18,7 +20,7 @@ function isComment(line) {
|
|
|
18
20
|
function getPropertiesAsJSON(filePath) {
|
|
19
21
|
try {
|
|
20
22
|
const data = (0, _fs.readFileSync)(filePath);
|
|
21
|
-
|
|
23
|
+
const source = data.toString();
|
|
22
24
|
const i18nObj = {};
|
|
23
25
|
source.split(/\r?\n\r?/).forEach(fline => {
|
|
24
26
|
const line = fline.trim();
|
|
@@ -42,7 +44,7 @@ function getPropertiesAsJSON(filePath) {
|
|
|
42
44
|
}
|
|
43
45
|
|
|
44
46
|
function getLang(file) {
|
|
45
|
-
|
|
47
|
+
const underScoreIndex = file.indexOf('_');
|
|
46
48
|
let language = 'en_US';
|
|
47
49
|
|
|
48
50
|
if (underScoreIndex !== -1) {
|
|
@@ -68,26 +70,24 @@ function getAllI18n({
|
|
|
68
70
|
const filePath = (0, _path.join)(context, file);
|
|
69
71
|
|
|
70
72
|
if (exclude.test(filePath) || !include.test(filePath)) {
|
|
71
|
-
// console.log('exclude', filePath);
|
|
72
73
|
return;
|
|
73
|
-
}
|
|
74
|
-
|
|
74
|
+
}
|
|
75
75
|
|
|
76
76
|
const i18n = getPropertiesAsJSON(filePath);
|
|
77
77
|
allLangI18n[getLang(file)] = disableDefault ? i18n : Object.assign({}, jsResourceI18nKeys, i18n);
|
|
78
78
|
});
|
|
79
79
|
return allLangI18n;
|
|
80
80
|
} catch (err) {
|
|
81
|
-
|
|
81
|
+
(0, _logger.errorLogger)(err);
|
|
82
82
|
return {};
|
|
83
83
|
}
|
|
84
84
|
}
|
|
85
85
|
|
|
86
86
|
function jsonToString(json, keySeperator) {
|
|
87
87
|
let str = '{';
|
|
88
|
-
|
|
88
|
+
const keys = Object.keys(json);
|
|
89
89
|
keys.forEach((key, i) => {
|
|
90
|
-
|
|
90
|
+
const value = json[key];
|
|
91
91
|
|
|
92
92
|
if (!value) {
|
|
93
93
|
return;
|
|
@@ -11,9 +11,9 @@ var _uglifycss = _interopRequireDefault(require("uglifycss"));
|
|
|
11
11
|
|
|
12
12
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
13
|
|
|
14
|
-
class
|
|
14
|
+
class MinifierPlugin {
|
|
15
15
|
apply(compiler) {
|
|
16
|
-
compiler.hooks.emit.tap('
|
|
16
|
+
compiler.hooks.emit.tap('MinifierPlugin', compilation => {
|
|
17
17
|
Object.keys(compilation.assets).forEach(filename => {
|
|
18
18
|
if (/\.css$/.test(filename)) {
|
|
19
19
|
try {
|
|
@@ -36,4 +36,4 @@ class UglifyCSSPlugin {
|
|
|
36
36
|
|
|
37
37
|
}
|
|
38
38
|
|
|
39
|
-
exports.default =
|
|
39
|
+
exports.default = MinifierPlugin;
|
|
@@ -33,25 +33,25 @@ class ResourceHintsPlugin {
|
|
|
33
33
|
}
|
|
34
34
|
|
|
35
35
|
return Template.asString([source, '', `${mainTemplate.requireFn}.getChunkId = function getChunkId(chunkId) {`, Template.indent((needsMap ? [`chunkId = ${JSON.stringify(nameIdMap)}[chunkId]||chunkId;`] : []).concat(['return chunkId;'])), '}', `// Prefetch a chunk (${pluginName})`, `${mainTemplate.requireFn}.pfc = function prefetchChunk(chunkId) {`, Template.indent([`chunkId = ${mainTemplate.requireFn}.getChunkId(chunkId)`, `${mainTemplate.requireFn}.e(chunkId);`]), '};',
|
|
36
|
-
/*
|
|
37
|
-
(needsMap
|
|
38
|
-
? [`chunkId = ${JSON.stringify(nameIdMap)}[chunkId]||chunkId;`]
|
|
39
|
-
: []
|
|
40
|
-
).concat([
|
|
41
|
-
'var promises = [];',
|
|
42
|
-
'if(installedChunks[chunkId] === undefined) {',
|
|
43
|
-
Template.indent([
|
|
44
|
-
'installedChunks[chunkId] = null;',
|
|
45
|
-
/* mainTemplate.hooks.linkPrefetch.call('', chunk, hash),
|
|
36
|
+
/*
|
|
37
|
+
(needsMap
|
|
38
|
+
? [`chunkId = ${JSON.stringify(nameIdMap)}[chunkId]||chunkId;`]
|
|
39
|
+
: []
|
|
40
|
+
).concat([
|
|
41
|
+
'var promises = [];',
|
|
42
|
+
'if(installedChunks[chunkId] === undefined) {',
|
|
43
|
+
Template.indent([
|
|
44
|
+
'installedChunks[chunkId] = null;',
|
|
45
|
+
/* mainTemplate.hooks.linkPrefetch.call('', chunk, hash),
|
|
46
46
|
'document.head.appendChild(link);', */
|
|
47
47
|
|
|
48
|
-
/*
|
|
49
|
-
mainTemplate.hooks.requireEnsure.call('', chunk, hash)
|
|
50
|
-
]),
|
|
51
|
-
'}'
|
|
52
|
-
])
|
|
53
|
-
),
|
|
54
|
-
'}',
|
|
48
|
+
/*
|
|
49
|
+
mainTemplate.hooks.requireEnsure.call('', chunk, hash)
|
|
50
|
+
]),
|
|
51
|
+
'}'
|
|
52
|
+
])
|
|
53
|
+
),
|
|
54
|
+
'}',
|
|
55
55
|
*/
|
|
56
56
|
`// Preload a chunk (${pluginName})`, `${mainTemplate.requireFn}.plc = function preloadChunk(chunkId) {`, Template.indent([`chunkId = ${mainTemplate.requireFn}.getChunkId(chunkId)`, 'if(installedChunks[chunkId] === undefined) {', Template.indent(['installedChunks[chunkId] = null;', mainTemplate.hooks.linkPreload.call('', chunk, hash), 'document.head.appendChild(link);', `${mainTemplate.requireFn}.e(chunkId);` // 'var head = document.getElementsByTagName(\'head\')[0];',
|
|
57
57
|
// mainTemplate.hooks.jsonpScript.call('', chunk, hash),
|
|
@@ -24,12 +24,12 @@ const isCss = filename => _path.default.extname(filename) === '.css'; // this p
|
|
|
24
24
|
|
|
25
25
|
class RtlCssPlugin {
|
|
26
26
|
constructor(options = {}) {
|
|
27
|
-
/**
|
|
28
|
-
* @typedef {Object} Options
|
|
29
|
-
* @property {String} filename [not used]
|
|
30
|
-
* @property {String} dirVarName
|
|
31
|
-
* @property {Boolean} sourcemap
|
|
32
|
-
* @property {Object} config
|
|
27
|
+
/**
|
|
28
|
+
* @typedef {Object} Options
|
|
29
|
+
* @property {String} filename [not used]
|
|
30
|
+
* @property {String} dirVarName
|
|
31
|
+
* @property {Boolean} sourcemap
|
|
32
|
+
* @property {Object} config
|
|
33
33
|
*/
|
|
34
34
|
this.options = {
|
|
35
35
|
filename: options.filename || '[name].rtl.css',
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
# RTL Split
|
|
2
|
-
|
|
3
|
-
we are doing in build time generating rtl related css code by using @zohodesk/postcss-rt npm.
|
|
4
|
-
It was automated, That postcss plugin create rtl reacted css and put them into same file, with css selector [dir=rtl] and ltr realted css with [dir=ltr].
|
|
5
|
-
Here is problem mostly no one need rtl and ltr related css at the same time in browser,
|
|
6
|
-
we are try to split them by [dir] and load which type of css is needed.
|
|
7
|
-
For this purpose we created RTL Split Plugin
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
# To Try it out rtl-ltr split
|
|
11
|
-
### how to use this feature?
|
|
12
|
-
|
|
13
|
-
to use this feature use have give the below oprtions
|
|
14
|
-
`package.json`
|
|
15
|
-
```json
|
|
16
|
-
{
|
|
17
|
-
/// ...some things
|
|
18
|
-
"react-cli": {
|
|
19
|
-
// ...some things
|
|
20
|
-
"css": {
|
|
21
|
-
"enableRTLSplit": true,
|
|
22
|
-
"templateLabel": "{{--dir}}",// this is for html template css file path dir template
|
|
23
|
-
"disableMiniFiySelector": false,
|
|
24
|
-
"dirVarName": "document.dir" // this will be used for download css based on dir
|
|
25
|
-
},
|
|
26
|
-
// ...some things
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
```
|
|
30
|
-
|
|
1
|
+
# RTL Split
|
|
2
|
+
|
|
3
|
+
we are doing in build time generating rtl related css code by using @zohodesk/postcss-rt npm.
|
|
4
|
+
It was automated, That postcss plugin create rtl reacted css and put them into same file, with css selector [dir=rtl] and ltr realted css with [dir=ltr].
|
|
5
|
+
Here is problem mostly no one need rtl and ltr related css at the same time in browser,
|
|
6
|
+
we are try to split them by [dir] and load which type of css is needed.
|
|
7
|
+
For this purpose we created RTL Split Plugin
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
# To Try it out rtl-ltr split
|
|
11
|
+
### how to use this feature?
|
|
12
|
+
|
|
13
|
+
to use this feature use have give the below oprtions
|
|
14
|
+
`package.json`
|
|
15
|
+
```json
|
|
16
|
+
{
|
|
17
|
+
/// ...some things
|
|
18
|
+
"react-cli": {
|
|
19
|
+
// ...some things
|
|
20
|
+
"css": {
|
|
21
|
+
"enableRTLSplit": true,
|
|
22
|
+
"templateLabel": "{{--dir}}",// this is for html template css file path dir template
|
|
23
|
+
"disableMiniFiySelector": false,
|
|
24
|
+
"dirVarName": "document.dir" // this will be used for download css based on dir
|
|
25
|
+
},
|
|
26
|
+
// ...some things
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
```
|
|
30
|
+
|
|
@@ -9,33 +9,26 @@ var _postcss = _interopRequireDefault(require("postcss"));
|
|
|
9
9
|
|
|
10
10
|
var _fs = _interopRequireDefault(require("fs"));
|
|
11
11
|
|
|
12
|
+
var _classHandling = require("./utils/classHandling");
|
|
13
|
+
|
|
14
|
+
var _fileHandling = require("./utils/fileHandling");
|
|
15
|
+
|
|
12
16
|
var _windowsModification = require("../loaderUtils/windowsModification");
|
|
13
17
|
|
|
14
18
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
15
19
|
|
|
16
|
-
function
|
|
17
|
-
let keyMatch = undefined;
|
|
18
|
-
Object.keys(data).forEach(key => {
|
|
19
|
-
if (filename.includes(key)) {
|
|
20
|
-
keyMatch = key;
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
return keyMatch;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
function rootConvertor(rootOriginal, defaultSelector, data, filename, excludeStrings) {
|
|
20
|
+
function selectorWeightPrefixAdder(rootOriginal, selector, excludeStrings) {
|
|
27
21
|
rootOriginal.walkRules((rule, index) => {
|
|
28
|
-
const prevNode = rootOriginal.nodes[index - 1];
|
|
22
|
+
const prevNode = rootOriginal.nodes[index - 1] ? rootOriginal.nodes[index - 1] : {};
|
|
29
23
|
|
|
30
|
-
if (
|
|
24
|
+
if ((0, _classHandling.hasPrevNodeIgnore)(index, prevNode, 'updateselector:ignore')) {
|
|
31
25
|
return;
|
|
32
26
|
}
|
|
33
27
|
|
|
34
|
-
if (
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
}
|
|
28
|
+
if (!(0, _classHandling.isInsideMediaQuery)(rule)) {
|
|
29
|
+
return;
|
|
30
|
+
} // console.log(rule.selector.split(','));
|
|
31
|
+
|
|
39
32
|
|
|
40
33
|
const selectorArr = rule.selector.split(',');
|
|
41
34
|
selectorArr.forEach((singleSelectorStr, index) => {
|
|
@@ -45,41 +38,33 @@ function rootConvertor(rootOriginal, defaultSelector, data, filename, excludeStr
|
|
|
45
38
|
|
|
46
39
|
if (singleSelectorStr.includes(']')) {
|
|
47
40
|
if (singleSelectorStr.slice(singleSelectorStr.lastIndexOf(']') + 2).trim() === '') {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
41
|
+
if (singleSelectorStr.slice(singleSelectorStr.lastIndexOf(']') + 2).trim() === '') {
|
|
42
|
+
return;
|
|
43
|
+
} // str = [dir=ltr] .zd-listpagination-wrapper:hover .zd-listpagination-upArw
|
|
44
|
+
// str.slice(0, str.lastIndexOf(']') + 1) -- [dir=ltr]
|
|
45
|
+
// str.slice(str.lastIndexOf(']') + 2).trim() -- .zd-listpagination-wrapper:hover .zd-listpagination-upArw
|
|
46
|
+
// ${str.slice(0, str.lastIndexOf(']') + 1).trim()} .selector ${str.slice(str.lastIndexOf(']') + 2).trim()} -- [dir=ltr] .selector .zd-listpagination-wrapper:hover .zd-listpagination-upArw
|
|
54
47
|
|
|
55
|
-
selectorArr[index] = `${singleSelectorStr.slice(0, singleSelectorStr.lastIndexOf(']') + 1).trim()} ${defaultSelector}${singleSelectorStr.slice(singleSelectorStr.lastIndexOf(']') + 2).trim()}`; // console.log(ruleArr[index]);
|
|
56
48
|
|
|
57
|
-
|
|
49
|
+
selectorArr[index] = `${singleSelectorStr.slice(0, singleSelectorStr.lastIndexOf(']') + 1).trim()} ${selector}${singleSelectorStr.slice(singleSelectorStr.lastIndexOf(']') + 2).trim()}`;
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
58
52
|
}
|
|
59
53
|
|
|
60
|
-
|
|
61
|
-
selectorArr[index] = data[keyMatch] ? `${data[keyMatch].defaultSelector}${singleSelectorStr}` : `${defaultSelector}${singleSelectorStr}`;
|
|
54
|
+
selectorArr[index] = `${selector}${singleSelectorStr}`;
|
|
62
55
|
});
|
|
63
|
-
rule.selector = selectorArr.join(',\n');
|
|
56
|
+
rule.selector = selectorArr.join(',\n');
|
|
64
57
|
});
|
|
65
58
|
return rootOriginal;
|
|
66
59
|
}
|
|
67
60
|
|
|
68
|
-
function ignoreFile(excludeArr, filename) {
|
|
69
|
-
let ignore = false;
|
|
70
|
-
excludeArr.forEach(exclStr => {
|
|
71
|
-
if (filename.includes(exclStr)) {
|
|
72
|
-
ignore = true;
|
|
73
|
-
}
|
|
74
|
-
});
|
|
75
|
-
return ignore;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
61
|
class SelectorPlugin {
|
|
79
62
|
constructor(options = {}) {
|
|
80
63
|
this.optimize = options.optimize;
|
|
81
64
|
this.selectorWeightConfig = options.selectorWeightConfig;
|
|
82
65
|
this.exclude = options.exclude;
|
|
66
|
+
this.patterns = options.patterns;
|
|
67
|
+
this.rootDir = options.patternsRootDir;
|
|
83
68
|
}
|
|
84
69
|
|
|
85
70
|
apply(compiler) {
|
|
@@ -99,16 +84,49 @@ class SelectorPlugin {
|
|
|
99
84
|
mods.forEach(module => {
|
|
100
85
|
const rootOriginal = _postcss.default.parse(module.content);
|
|
101
86
|
|
|
102
|
-
const filename = module.issuer.resource;
|
|
103
|
-
|
|
104
|
-
|
|
87
|
+
const filename = module.issuer.resource;
|
|
88
|
+
/*
|
|
89
|
+
input :
|
|
90
|
+
filename : 'D:/MyWork/..../desk_client_app/supportapp/src/components/Avatar/Avatar.module.css,
|
|
91
|
+
|
|
92
|
+
patterns.cssVariableReplacement:
|
|
93
|
+
// include src folder, include deskapp folder, exclude node modules
|
|
94
|
+
"selectorWeight": [
|
|
95
|
+
"src",
|
|
96
|
+
"deskapp",
|
|
97
|
+
"!node_modules"
|
|
98
|
+
]
|
|
99
|
+
rootDir : patternsRootDir : 'supportapp'
|
|
100
|
+
|
|
101
|
+
output :
|
|
102
|
+
true or false
|
|
103
|
+
*/
|
|
104
|
+
|
|
105
|
+
if (!(0, _fileHandling.isFileNameMatchingPluginPattern)({
|
|
106
|
+
filename,
|
|
107
|
+
filterArr: this.patterns.selectorWeight,
|
|
108
|
+
rootDir: this.rootDir
|
|
109
|
+
})) {
|
|
105
110
|
return;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
module.
|
|
110
|
-
|
|
111
|
-
|
|
111
|
+
}
|
|
112
|
+
/*
|
|
113
|
+
|
|
114
|
+
filename : Deskapp.module.css ?
|
|
115
|
+
data :
|
|
116
|
+
{
|
|
117
|
+
"DeskApp.module.css": {"defaultSelector" : ".desk_app_ui "}
|
|
118
|
+
}
|
|
119
|
+
selectorWeightConfig :
|
|
120
|
+
defaultSelector : .zoho_desk_ui
|
|
121
|
+
|
|
122
|
+
case filename = 'DeskApp.module.css' ?
|
|
123
|
+
data[filename].defaultSelector = '.desk_app_ui'
|
|
124
|
+
case filename is different ?
|
|
125
|
+
defaultSelector = '.zoho_desk_ui'
|
|
126
|
+
*/
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
module.content = selectorWeightPrefixAdder(rootOriginal, data[filename] ? data[filename].defaultSelector : defaultSelector, excludeStrings).toString();
|
|
112
130
|
});
|
|
113
131
|
});
|
|
114
132
|
});
|
|
@@ -51,11 +51,11 @@ class ServiceWorkerPlugin {
|
|
|
51
51
|
if (err) {
|
|
52
52
|
throw new Error(err);
|
|
53
53
|
} else {
|
|
54
|
-
/* const extractedChunks = compilation.chunks.filter(chunk => {
|
|
55
|
-
if ('canBeInitial' in chunk) {
|
|
56
|
-
return chunk.canBeInitial();
|
|
57
|
-
}
|
|
58
|
-
return chunk.isInitial();
|
|
54
|
+
/* const extractedChunks = compilation.chunks.filter(chunk => {
|
|
55
|
+
if ('canBeInitial' in chunk) {
|
|
56
|
+
return chunk.canBeInitial();
|
|
57
|
+
}
|
|
58
|
+
return chunk.isInitial();
|
|
59
59
|
}); */
|
|
60
60
|
// let [js, css, , , i18nPublicPath] = this.publicPaths;
|
|
61
61
|
// let initialChunkUrls = [];
|
|
@@ -64,10 +64,10 @@ class ServiceWorkerPlugin {
|
|
|
64
64
|
let entrypoint = compilation.entrypoints.get('main');
|
|
65
65
|
let initialChunkUrls = entrypoint.getFiles();
|
|
66
66
|
const cssDirTemplate = '@dir@';
|
|
67
|
-
/**
|
|
68
|
-
* NOTE:
|
|
69
|
-
* if chunkSplitEnable is false means,
|
|
70
|
-
* serviceWorker will get i18n files path for html
|
|
67
|
+
/**
|
|
68
|
+
* NOTE:
|
|
69
|
+
* if chunkSplitEnable is false means,
|
|
70
|
+
* serviceWorker will get i18n files path for html
|
|
71
71
|
*/
|
|
72
72
|
|
|
73
73
|
let initalI18nAssets = chunkSplitEnable ? entrypoint.chunks.filter(chunk => _I18nKeysIdentifer.default.isChunkHasI18n(chunk)).map(chunk => (0, _getI18nFileUrlPathTemplate.getI18nFileUrlPathTemplate)(compilation, chunk, this.i18nFileNameTemplate, '@locale@')) : [];
|
|
@@ -15,10 +15,10 @@ var _crypto = _interopRequireDefault(require("crypto"));
|
|
|
15
15
|
|
|
16
16
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
17
17
|
|
|
18
|
-
/**
|
|
19
|
-
* Plugin that generates hash for the provided list of third party files
|
|
20
|
-
* Map the provided key with the file hash and add it to the list of exisiting global constants.
|
|
21
|
-
* Plugin in turn uses the defineplugin to generate global constants.
|
|
18
|
+
/**
|
|
19
|
+
* Plugin that generates hash for the provided list of third party files
|
|
20
|
+
* Map the provided key with the file hash and add it to the list of exisiting global constants.
|
|
21
|
+
* Plugin in turn uses the defineplugin to generate global constants.
|
|
22
22
|
*/
|
|
23
23
|
class TPHashMappingPlugin {
|
|
24
24
|
constructor(options) {
|