@zohodesk/react-cli 0.0.1-beta.175 → 0.0.1-beta.176
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/README.md +1018 -1010
- package/bin/cli.js +482 -482
- package/cert/Tsicsezwild-22-23.crt +37 -37
- package/cert/Tsicsezwild-22-23.key +27 -27
- package/docs/CustomChunks.md +26 -26
- package/docs/DevStart.md +18 -18
- package/docs/HoverActive.md +12 -12
- package/docs/InstallNode.md +28 -28
- package/docs/SelectorWeight.md +6 -0
- package/docs/TODOS.md +10 -10
- package/docs/ValueReplacer.md +60 -60
- package/docs/VariableConversion.md +710 -678
- package/docs/warnings_while_install.txt +35 -35
- package/files/eslintrc.js +62 -62
- package/files/prettierrc.js +3 -3
- package/lib/configs/webpack.css.umd.config.js +4 -4
- package/lib/configs/webpack.dev.config.js +23 -2
- package/lib/configs/webpack.docs.config.js +13 -1
- package/lib/configs/webpack.impact.config.js +13 -1
- package/lib/configs/webpack.prod.config.js +23 -2
- package/lib/loaderUtils/configsAssetsLoaders.js +33 -33
- package/lib/loaderUtils/getCSSLoaders.js +24 -21
- package/lib/loaderUtils/windowsModification.js +11 -0
- package/lib/loaders/workerLoader.js +9 -9
- package/lib/pluginUtils/configHtmlWebpackPlugins.js +0 -3
- package/lib/pluginUtils/getDevPlugins.js +42 -20
- package/lib/pluginUtils/getProdPlugins.js +45 -24
- package/lib/plugins/EFCPlugin.md +6 -6
- package/lib/plugins/I18NInjectIntoIndexPlugin.js +4 -4
- package/lib/plugins/I18nSplitPlugin/I18nDownlodLogic.js +38 -38
- package/lib/plugins/I18nSplitPlugin/I18nFilesEmitter.js +30 -30
- package/lib/plugins/I18nSplitPlugin/I18nKeysIdentifer.js +8 -8
- 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/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 +97 -0
- package/lib/plugins/ServiceWorkerPlugin.js +9 -9
- package/lib/plugins/TPHashMappingPlugin.js +4 -4
- package/lib/plugins/VariableConversionCollector.js +252 -0
- package/lib/plugins/composeCommonPlugin.js +30 -0
- package/lib/postcss-plugins/RTLSplitPlugin.js +10 -10
- 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 -3
- package/lib/postcss-plugins/variableModificationPlugin/ErrorHandler.js +35 -14
- package/lib/postcss-plugins/variableModificationPlugin/index.js +202 -143
- package/lib/schemas/index.js +18 -4
- 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/resultSchema.json +73 -73
- package/npm8.md +9 -9
- package/package.json +146 -146
- package/postpublish.js +6 -6
- 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
@@ -6,8 +6,13 @@ const fs = require('fs');
|
|
6
6
|
|
7
7
|
const path = require('path');
|
8
8
|
|
9
|
+
const {
|
10
|
+
ErrorHandler
|
11
|
+
} = require('./ErrorHandler');
|
12
|
+
|
9
13
|
const errors = [];
|
10
|
-
|
14
|
+
const errorTable = [];
|
15
|
+
const errHandler = new ErrorHandler();
|
11
16
|
const convertableProps = {
|
12
17
|
'font-size': true,
|
13
18
|
margin: true,
|
@@ -29,19 +34,37 @@ const convertableProps = {
|
|
29
34
|
top: true,
|
30
35
|
bottom: true,
|
31
36
|
left: true,
|
32
|
-
right: true
|
37
|
+
right: true,
|
38
|
+
'text-indent': true,
|
39
|
+
clip: true,
|
40
|
+
'flex-basis': true,
|
41
|
+
'row-gap': true,
|
42
|
+
gap: true,
|
43
|
+
'column-gap': true,
|
44
|
+
flex: true
|
33
45
|
};
|
34
46
|
const constantValues = {
|
35
47
|
inherit: true,
|
36
48
|
initial: true,
|
37
49
|
auto: true,
|
38
50
|
'fit-content': true,
|
39
|
-
unset: true
|
51
|
+
unset: true,
|
52
|
+
cover: true,
|
53
|
+
contain: true,
|
54
|
+
top: true,
|
55
|
+
bottom: true,
|
56
|
+
left: true,
|
57
|
+
center: true,
|
58
|
+
right: true
|
40
59
|
};
|
41
60
|
|
42
61
|
function getNumericValue(value) {
|
43
62
|
if (value.includes('var')) {
|
44
63
|
return parseInt(value.replace(/var\(--zd_size(\d+)\)/gi, '$1').replace(/var\(--zd_font_size(\d+)\)/gi, '$1'));
|
64
|
+
}
|
65
|
+
|
66
|
+
if (value.includes('rect')) {
|
67
|
+
return parseInt(value.replace('rect(', '').replace(')', '').replace(',', ''));
|
45
68
|
} // Not need for this dum loop
|
46
69
|
// allowed.forEach(alwdUnit => {
|
47
70
|
// if (value.includes(alwdUnit)) {
|
@@ -71,22 +94,6 @@ function pxToCalc(value) {
|
|
71
94
|
return arr.join(' ');
|
72
95
|
}
|
73
96
|
|
74
|
-
const addError = errstr => {
|
75
|
-
errors.push(`{\n${errstr}\n}\n`);
|
76
|
-
};
|
77
|
-
|
78
|
-
const errorFunction = (errStr, type) => {
|
79
|
-
if (type === 'DECLARATION_IGNORED' && allowedErrs.DECLARATION_IGNORED) {
|
80
|
-
addError(errStr);
|
81
|
-
} else if (type === 'UNIT_ERROR' && allowedErrs.UNIT_ERROR) {
|
82
|
-
addError(errStr);
|
83
|
-
} else if (type === 'RANGE_ERROR' && allowedErrs.RANGE_ERROR) {
|
84
|
-
addError(errStr);
|
85
|
-
} else if (type === 'VARIABLE_PRESENT' && allowedErrs.VARIABLE_PRESENT) {
|
86
|
-
addError(errStr);
|
87
|
-
}
|
88
|
-
};
|
89
|
-
|
90
97
|
const singleConvertor = (value, changeVal, details, range) => {
|
91
98
|
const {
|
92
99
|
path,
|
@@ -94,6 +101,13 @@ const singleConvertor = (value, changeVal, details, range) => {
|
|
94
101
|
decl
|
95
102
|
} = details;
|
96
103
|
|
104
|
+
if (decl.prop === 'background-position') {
|
105
|
+
if (isNaN(parseInt(value))) {
|
106
|
+
// console.log(`${value} skipped`);
|
107
|
+
return;
|
108
|
+
}
|
109
|
+
}
|
110
|
+
|
97
111
|
if (getNumericValue(value) >= range.start && getNumericValue(value) <= range.end || getNumericValue(value) === 0) {
|
98
112
|
let retVal = value.replace(/(\d+)px/gi, changeVal.replace('$$', '$1'));
|
99
113
|
|
@@ -102,146 +116,191 @@ const singleConvertor = (value, changeVal, details, range) => {
|
|
102
116
|
}
|
103
117
|
|
104
118
|
return retVal;
|
105
|
-
} // if(
|
119
|
+
} // if (!value.includes('rect')) {
|
120
|
+
// if(unitErrorVal && unitErrorVal != '0' ){
|
106
121
|
// console.log(value, 'not within range')
|
107
122
|
|
108
123
|
|
109
|
-
|
124
|
+
let errObj = {
|
125
|
+
decl,
|
126
|
+
type: 'RANGE_ERROR',
|
127
|
+
filename,
|
128
|
+
message: `value (${value}) (${typeof value}) not within range (${range.start},${range.end})\r`,
|
129
|
+
path: path
|
130
|
+
};
|
131
|
+
errHandler.errorTable.push(errObj);
|
132
|
+
errHandler.errorFunction(errObj); // errorFunction(
|
133
|
+
// {
|
134
|
+
// decl,
|
135
|
+
// type: 'RANGE_ERROR',
|
136
|
+
// filename,
|
137
|
+
// message: `value (${value}) (${typeof value}) not within range (${
|
138
|
+
// range.start
|
139
|
+
// },${range.end})\r`,
|
140
|
+
// path: path
|
141
|
+
// },
|
142
|
+
// 'RANGE_ERROR'
|
143
|
+
// );
|
144
|
+
// }
|
110
145
|
// addError(` prop: ${decl.prop} ,\n value : ${decl.value} ,\n filename : ${filename} ,\n filepath : ${path} ,\n line : ${decl.source.start.line} ,\n message : value (${value}) not within range (${range.start},${range.end})\r`)
|
111
|
-
|
112
|
-
|
146
|
+
// return value;
|
147
|
+
// } else {
|
148
|
+
// console.log('++++++++++++++++++++++rect val!', value);
|
149
|
+
// }
|
113
150
|
};
|
114
151
|
|
115
|
-
module.exports =
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
Object.
|
129
|
-
|
130
|
-
replacementArray.
|
152
|
+
module.exports = {
|
153
|
+
plugin: postcss.plugin('postcss-variable-report', cssVariableReplacementConfig => {
|
154
|
+
const rawdata = fs.readFileSync(cssVariableReplacementConfig);
|
155
|
+
const data = JSON.parse(rawdata);
|
156
|
+
const {
|
157
|
+
errorsAllowed,
|
158
|
+
settings: settingsObject // errorLog: errorLogStatus,
|
159
|
+
// errorInConsole: errorConsoleStatus
|
160
|
+
|
161
|
+
} = data; // const keys = Object.keys(settingsObject);
|
162
|
+
|
163
|
+
errHandler.setAllowedErrs(errorsAllowed);
|
164
|
+
const replacementArray = [];
|
165
|
+
Object.keys(settingsObject).forEach(key => {
|
166
|
+
Object.values(settingsObject[key].replacements).forEach(val => {
|
167
|
+
if (!replacementArray.includes(val)) {
|
168
|
+
replacementArray.push(val);
|
169
|
+
}
|
170
|
+
});
|
171
|
+
});
|
172
|
+
let regValStr = '';
|
173
|
+
replacementArray.forEach((val, index) => {
|
174
|
+
if (index !== replacementArray.length - 1) {
|
175
|
+
regValStr += `${val.replace('$$', '\\d+').replace('(', '\\(').replace(')', '\\)')}|`;
|
176
|
+
} else {
|
177
|
+
regValStr += `${val.replace('$$', '\\d+').replace('(', '\\(').replace(')', '\\)')}`;
|
131
178
|
}
|
132
179
|
});
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
rootOriginal.walkRules(rule => {
|
145
|
-
// rule.nodes[-1] = {}
|
146
|
-
// need map, forEach fine less memory
|
147
|
-
rule.nodes.forEach((decl, position) => {
|
148
|
-
// case font-size
|
149
|
-
const commentStr = 'variable:ignore';
|
150
|
-
const prevNode = rule.nodes[position - 1];
|
151
|
-
const fromPath = rootOriginal.source.input.from; // this will be problem for linux and mac use require('path').sep
|
152
|
-
// split not need use slice and lastIndexOf less memory
|
153
|
-
|
154
|
-
const filename = fromPath.split(path.sep).pop();
|
155
|
-
|
156
|
-
if (prevNode && prevNode.type === 'comment' && prevNode.text.toLowerCase().includes(commentStr)) {
|
157
|
-
const errStr = ` prop: ${decl.prop} ,\n value : ${decl.value} ,\n filename : ${filename} ,\n filepath : ${fromPath} ,\n line : ${decl.source.start.line} ,\n message : Declaration Ignored \r`;
|
158
|
-
errorFunction(errStr, 'DECLARATION_IGNORED');
|
159
|
-
return;
|
160
|
-
}
|
180
|
+
const valRegex = new RegExp(regValStr, 'gi');
|
181
|
+
return rootOriginal => {
|
182
|
+
rootOriginal.walkRules(rule => {
|
183
|
+
// rule.nodes[-1] = {}
|
184
|
+
// need map, forEach fine less memory
|
185
|
+
rule.nodes.forEach((decl, position) => {
|
186
|
+
// case font-size
|
187
|
+
const commentStr = 'variable:ignore';
|
188
|
+
const prevNode = rule.nodes[position - 1];
|
189
|
+
const fromPath = rootOriginal.source.input.from; // this will be problem for linux and mac use require('path').sep
|
190
|
+
// split not need use slice and lastIndexOf less memory
|
161
191
|
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
192
|
+
const filename = fromPath.split(path.sep).pop();
|
193
|
+
|
194
|
+
if (prevNode && prevNode.type === 'comment' && prevNode.text.toLowerCase().includes(commentStr)) {
|
195
|
+
let errObj = {
|
196
|
+
decl,
|
197
|
+
type: 'DECLARATION_IGNORED',
|
198
|
+
filename,
|
199
|
+
message: 'Declaration Ignored',
|
200
|
+
path: fromPath
|
201
|
+
};
|
202
|
+
errHandler.errorTable.push(errObj);
|
203
|
+
errHandler.DECLARATION_IGNORED(errObj);
|
204
|
+
return;
|
205
|
+
}
|
206
|
+
|
207
|
+
if (settingsObject[decl.prop] && !decl.value.includes('var(--')) {
|
208
|
+
const settings = settingsObject[decl.prop]; // console.log(settings)
|
209
|
+
|
210
|
+
const {
|
211
|
+
allowed,
|
212
|
+
range
|
213
|
+
} = settings; // suggestion filter !decl.value.includes('calc')
|
214
|
+
// Reason below some of logic happen based on this
|
215
|
+
|
216
|
+
const unit = decl.value.toString() // no need round braket since you do not need group for less memory
|
217
|
+
.replace(/\d+/gi, '').replace('var(--zd_size)', 'px').replace('var(--zd_font_size)', 'px').replace('rect(', '').replace(')', '').replace('px,', 'px').replace(',', '').split(' ').filter(x => x !== ''); // unit = unit.replace(unit, unit.replace('-',''))
|
218
|
+
// console.log('unit : ');
|
219
|
+
// console.log(unit);
|
220
|
+
|
221
|
+
unit.forEach((val, index) => {
|
222
|
+
allowed.forEach(alwdVal => {
|
223
|
+
if (val.includes(alwdVal)) {
|
224
|
+
// ## for what purpose
|
225
|
+
unit[index] = val // .replace(new RegExp('(\\d+).(\\d+)(\\w+)', 'gi'), '$3')
|
226
|
+
.replace(`-${alwdVal}`, `${alwdVal}`).replace(`-.${alwdVal}`, `${alwdVal}`).replace(`${alwdVal},`, `${alwdVal}`);
|
227
|
+
}
|
228
|
+
});
|
182
229
|
});
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
230
|
+
let unitError = false;
|
231
|
+
let unitErrorVal = '';
|
232
|
+
unit.forEach(val => {
|
233
|
+
if (!val.includes('calc') && decl.prop !== 'clip') {
|
234
|
+
if (!allowed.includes(val.toString())) {
|
235
|
+
unitError = true;
|
236
|
+
unitErrorVal = val;
|
237
|
+
}
|
191
238
|
}
|
192
|
-
}
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
239
|
+
}); // console.log(allowed, replacements, range)
|
240
|
+
|
241
|
+
if (!unitError) {
|
242
|
+
// use variable decl.value.split(' ')
|
243
|
+
if (range) {
|
244
|
+
// console.log('multiple :', decl.value)
|
245
|
+
let newVal = '';
|
246
|
+
decl.value.split(' ').forEach(singleVal => {
|
247
|
+
newVal += `${singleConvertor(singleVal, settings.replacements.px, {
|
248
|
+
decl,
|
249
|
+
filename,
|
250
|
+
path: fromPath
|
251
|
+
}, range)} `;
|
252
|
+
});
|
253
|
+
decl.value = newVal;
|
254
|
+
}
|
255
|
+
} else {
|
256
|
+
if (!decl.value.includes('calc')) {
|
257
|
+
// addError(` prop: ${decl.prop} ,\n value : ${decl.value} ,\n filename : ${filename} ,\n filepath : ${path} ,\n line : ${decl.source.start.line} ,\n unit : ${unitErrorVal} ,\n message : ${unitErrorVal} (Unit) Not Allowed \r`);
|
258
|
+
let errObj = {
|
202
259
|
decl,
|
203
260
|
filename,
|
261
|
+
unitErrorVal: unitErrorVal,
|
204
262
|
path: fromPath
|
205
|
-
}
|
206
|
-
|
207
|
-
|
263
|
+
};
|
264
|
+
|
265
|
+
if (unitErrorVal.trim() === '.') {
|
266
|
+
errObj.type = 'DECIMAL_CHECK';
|
267
|
+
errObj.message = `${unitErrorVal} (Decimal Value) Please check`;
|
268
|
+
errHandler.errorTable.push(errObj);
|
269
|
+
errHandler.DECIMAL_CHECK(errObj);
|
270
|
+
} else if (unitErrorVal.includes('.') && !unitErrorVal.includes('%')) {
|
271
|
+
errObj.type = 'DECIMAL_REJECT';
|
272
|
+
errObj.message = `${unitErrorVal} (Decimal Value) Not Allowed \r`;
|
273
|
+
errHandler.errorTable.push(errObj);
|
274
|
+
errHandler.DECIMAL_REJECT(errObj);
|
275
|
+
} else {
|
276
|
+
if (!unitErrorVal.includes('%')) {
|
277
|
+
errObj.type = 'UNIT_ERROR';
|
278
|
+
errObj.message = `${unitErrorVal} (Unit) Not Allowed`;
|
279
|
+
errHandler.errorTable.push(errObj);
|
280
|
+
errHandler.UNIT_ERROR(errObj);
|
281
|
+
}
|
282
|
+
}
|
283
|
+
} else {
|
284
|
+
decl.value = pxToCalc(decl.value);
|
285
|
+
}
|
208
286
|
}
|
209
287
|
} else {
|
210
|
-
if (!decl.value.includes('calc')) {
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
|
288
|
+
if (decl.prop && decl.value && !decl.prop.includes('--') && valRegex.test(decl.value) && (settingsObject[decl.prop] || convertableProps[decl.prop]) && decl.value.includes('var') && !decl.value.includes('calc')) {
|
289
|
+
let errObj = {
|
290
|
+
decl,
|
291
|
+
type: 'VARIABLE_PRESENT',
|
292
|
+
filename,
|
293
|
+
message: `value (${decl.value}) has var in it, kindly check`,
|
294
|
+
path: fromPath
|
295
|
+
};
|
296
|
+
errHandler.errorTable.push(errObj);
|
297
|
+
errHandler.VARIABLE_PRESENT(errObj);
|
215
298
|
}
|
216
299
|
}
|
217
|
-
} else {
|
218
|
-
if (decl.prop && decl.value && !decl.prop.includes('--') && valRegex.test(decl.value) && (settingsObject[decl.prop] || convertableProps[decl.prop]) && decl.value.includes('var') && !decl.value.includes('calc')) {
|
219
|
-
errorFunction(` prop: ${decl.prop} ,\n value : ${decl.value} ,\n filename : ${filename} ,\n filepath : ${fromPath} ,\n line : ${decl.source.start.line} ,\n message : value (${decl.value}) has var in it, kindly check`, 'VARIABLE_PRESENT');
|
220
|
-
}
|
221
|
-
}
|
222
|
-
});
|
223
|
-
}); // console.log(filename)
|
224
|
-
// console.log('Done!')
|
225
|
-
// console.log('----------------------------------------------------------------------------------------------------------------------')
|
226
|
-
|
227
|
-
if (errorLogStatus) {
|
228
|
-
fs.writeFileSync('./css_error.log', '');
|
229
|
-
|
230
|
-
if (errors.length > 0) {
|
231
|
-
errors.forEach(err => {
|
232
|
-
fs.appendFileSync('./css_error.log', err);
|
233
|
-
}); // console.log('----------------------------------------------------------------------------------------------------------------------')
|
234
|
-
}
|
235
|
-
}
|
236
|
-
|
237
|
-
if (errorConsoleStatus) {
|
238
|
-
if (errors.length > 0) {
|
239
|
-
errors.forEach(err => {
|
240
|
-
// fs.appendFileSync('./css_error.log', err);
|
241
|
-
console.log(err);
|
242
300
|
});
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
301
|
+
});
|
302
|
+
};
|
303
|
+
}),
|
304
|
+
errors: errHandler.errors,
|
305
|
+
errTable: errHandler.errorTable
|
306
|
+
};
|
package/lib/schemas/index.js
CHANGED
@@ -217,15 +217,22 @@ var _default = {
|
|
217
217
|
hasRTL: false,
|
218
218
|
hoverActive: false,
|
219
219
|
combinerMediaQuery: false,
|
220
|
-
cssVariableReplacement: false
|
220
|
+
cssVariableReplacement: false,
|
221
|
+
selectorWeight: false
|
221
222
|
},
|
222
223
|
exclude: {
|
223
224
|
rtl: [],
|
224
225
|
hoverActive: [],
|
225
226
|
combinerMediaQuery: [],
|
226
|
-
cssVariableReplacement: []
|
227
|
+
cssVariableReplacement: [],
|
228
|
+
selectorWeight: []
|
227
229
|
},
|
228
230
|
cssVariableReplacementConfig: '',
|
231
|
+
selectorWeightConfig: {
|
232
|
+
defaultSelector: '',
|
233
|
+
customFileDetails: '',
|
234
|
+
excludeStrings: []
|
235
|
+
},
|
229
236
|
seperateCssModules: {
|
230
237
|
value: false,
|
231
238
|
cli: 'sep_cssmodules'
|
@@ -307,15 +314,22 @@ var _default = {
|
|
307
314
|
hasRTL: false,
|
308
315
|
hoverActive: false,
|
309
316
|
combinerMediaQuery: false,
|
310
|
-
cssVariableReplacement: false
|
317
|
+
cssVariableReplacement: false,
|
318
|
+
selectorWeight: false
|
311
319
|
},
|
312
320
|
exclude: {
|
313
321
|
rtl: [],
|
314
322
|
hoverActive: [],
|
315
323
|
combinerMediaQuery: [],
|
316
|
-
cssVariableReplacement: []
|
324
|
+
cssVariableReplacement: [],
|
325
|
+
selectorWeight: []
|
317
326
|
},
|
318
327
|
cssVariableReplacementConfig: '',
|
328
|
+
selectorWeightConfig: {
|
329
|
+
defaultSelector: '',
|
330
|
+
customFileDetails: '',
|
331
|
+
excludeStrings: []
|
332
|
+
},
|
319
333
|
cssHashSelectors: {
|
320
334
|
filenames: [],
|
321
335
|
packages: []
|
package/lib/sh/pre-commit.sh
CHANGED
@@ -1,34 +1,34 @@
|
|
1
|
-
#!/bin/sh
|
2
|
-
|
3
|
-
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep -E "\.(js)$") # Get staged files
|
4
|
-
|
5
|
-
CURRENT_BRANCH=$(git branch | sed -n -e 's/^\* \(.*\)/\1/p') # Get branch name
|
6
|
-
|
7
|
-
echo "Branch Name - $CURRENT_BRANCH"
|
8
|
-
|
9
|
-
if [[ "$STAGED_FILES" = "" ]]; then
|
10
|
-
exit 0
|
11
|
-
fi
|
12
|
-
|
13
|
-
IS_FAILED=false
|
14
|
-
FILES=""
|
15
|
-
|
16
|
-
for FILE in $STAGED_FILES # Add files with space separation
|
17
|
-
do
|
18
|
-
FILES+="$FILE "
|
19
|
-
done
|
20
|
-
|
21
|
-
npm run lint --prefix ${PREFIX_PATH} $FILES # Run ESLint
|
22
|
-
|
23
|
-
if [[ "$?" != 0 ]]; then
|
24
|
-
IS_FAILED=true
|
25
|
-
fi
|
26
|
-
|
27
|
-
if $IS_FAILED; then
|
28
|
-
echo "\033[41mCOMMIT FAILED:\033[0m Your commit contains files that should pass ESLint but do not. Please fix the ESLint errors and try again.\n"
|
29
|
-
exit 1
|
30
|
-
else
|
31
|
-
echo "\033[42mCOMMIT SUCCEEDED\033[0m\n"
|
32
|
-
fi
|
33
|
-
|
34
|
-
exit $?
|
1
|
+
#!/bin/sh
|
2
|
+
|
3
|
+
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep -E "\.(js)$") # Get staged files
|
4
|
+
|
5
|
+
CURRENT_BRANCH=$(git branch | sed -n -e 's/^\* \(.*\)/\1/p') # Get branch name
|
6
|
+
|
7
|
+
echo "Branch Name - $CURRENT_BRANCH"
|
8
|
+
|
9
|
+
if [[ "$STAGED_FILES" = "" ]]; then
|
10
|
+
exit 0
|
11
|
+
fi
|
12
|
+
|
13
|
+
IS_FAILED=false
|
14
|
+
FILES=""
|
15
|
+
|
16
|
+
for FILE in $STAGED_FILES # Add files with space separation
|
17
|
+
do
|
18
|
+
FILES+="$FILE "
|
19
|
+
done
|
20
|
+
|
21
|
+
npm run lint --prefix ${PREFIX_PATH} $FILES # Run ESLint
|
22
|
+
|
23
|
+
if [[ "$?" != 0 ]]; then
|
24
|
+
IS_FAILED=true
|
25
|
+
fi
|
26
|
+
|
27
|
+
if $IS_FAILED; then
|
28
|
+
echo "\033[41mCOMMIT FAILED:\033[0m Your commit contains files that should pass ESLint but do not. Please fix the ESLint errors and try again.\n"
|
29
|
+
exit 1
|
30
|
+
else
|
31
|
+
echo "\033[42mCOMMIT SUCCEEDED\033[0m\n"
|
32
|
+
fi
|
33
|
+
|
34
|
+
exit $?
|
package/lib/sh/reportPublish.sh
CHANGED
@@ -1,45 +1,45 @@
|
|
1
|
-
#!/bin/bash
|
2
|
-
branchName=$2
|
3
|
-
url=$1
|
4
|
-
zipUrl=$3
|
5
|
-
unique=$(date +"%d_%m_%y_Time_%H_%M_%S")
|
6
|
-
publishFolder=$branchName"_"$unique
|
7
|
-
|
8
|
-
rm -rf ./reports
|
9
|
-
rm -rf ./scrTemplate
|
10
|
-
rm -rf ./errTemplate
|
11
|
-
rm -rf ./css
|
12
|
-
rm -rf ./js
|
13
|
-
rm -rf ./index.html
|
14
|
-
|
15
|
-
curl $zipUrl | tar xz
|
16
|
-
|
17
|
-
cp -rf ./reports/css ./css
|
18
|
-
cp -rf ./reports/js ./js
|
19
|
-
cp -rf ./reports/index.html ./index.html
|
20
|
-
if [ -d "./screenShots" ] ; then
|
21
|
-
cp -rf ./scrTemplate/* ./screenShots/
|
22
|
-
else
|
23
|
-
mkdir ./screenShots
|
24
|
-
cp -rf ./scrTemplate/* ./screenShots/
|
25
|
-
fi
|
26
|
-
|
27
|
-
[ ! -f "./result.json" ] && touch result.json && cp -rf ./errTemplate/* ./result.json
|
28
|
-
[ ! -d "./commitCoverage" ] && mkdir commitCoverage && cp -rf ./errTemplate/* ./commitCoverage/
|
29
|
-
[ ! -d "./unittest" ] && mkdir unittest && cp -rf ./errTemplate/* ./unittest/
|
30
|
-
[ ! -d "./coverageTest" ] && mkdir coverageTest && cp -rf ./errTemplate/* ./coverageTest/
|
31
|
-
[ ! -d "./coverage" ] && mkdir coverage && cp -rf ./errTemplate/* ./coverage/
|
32
|
-
|
33
|
-
tar -czvf $publishFolder.tar.gz coverage screenShots unittest coverageTest commitCoverage ./css ./js ./index.html ./result.json
|
34
|
-
|
35
|
-
curl -i -F name=file -F file=@$publishFolder.tar.gz $url"/cgi-bin/upload.py"
|
36
|
-
replace=$publishFolder
|
37
|
-
reportUrl=$url"/"$replace
|
38
|
-
subject="Client Report - React - $publishFolder"
|
39
|
-
msg="<p><b>Report URL - <a href='$reportUrl'>Link</a></b></p>
|
40
|
-
<p><b>Report Branchname - $branchName</b></p>
|
41
|
-
<p><b>Report Unique ID - $unique</b></p>
|
42
|
-
<p><b>Report Developer - $6</b></p>"
|
43
|
-
#node mailSender.js <from> <pass> <to> <subject> <text>
|
44
|
-
BASEDIR=$(dirname "$0")
|
45
|
-
node $BASEDIR"/../utils/mailSender" $4 $5 $6 "$subject" "$msg" $7 $8 "$reportUrl"
|
1
|
+
#!/bin/bash
|
2
|
+
branchName=$2
|
3
|
+
url=$1
|
4
|
+
zipUrl=$3
|
5
|
+
unique=$(date +"%d_%m_%y_Time_%H_%M_%S")
|
6
|
+
publishFolder=$branchName"_"$unique
|
7
|
+
|
8
|
+
rm -rf ./reports
|
9
|
+
rm -rf ./scrTemplate
|
10
|
+
rm -rf ./errTemplate
|
11
|
+
rm -rf ./css
|
12
|
+
rm -rf ./js
|
13
|
+
rm -rf ./index.html
|
14
|
+
|
15
|
+
curl $zipUrl | tar xz
|
16
|
+
|
17
|
+
cp -rf ./reports/css ./css
|
18
|
+
cp -rf ./reports/js ./js
|
19
|
+
cp -rf ./reports/index.html ./index.html
|
20
|
+
if [ -d "./screenShots" ] ; then
|
21
|
+
cp -rf ./scrTemplate/* ./screenShots/
|
22
|
+
else
|
23
|
+
mkdir ./screenShots
|
24
|
+
cp -rf ./scrTemplate/* ./screenShots/
|
25
|
+
fi
|
26
|
+
|
27
|
+
[ ! -f "./result.json" ] && touch result.json && cp -rf ./errTemplate/* ./result.json
|
28
|
+
[ ! -d "./commitCoverage" ] && mkdir commitCoverage && cp -rf ./errTemplate/* ./commitCoverage/
|
29
|
+
[ ! -d "./unittest" ] && mkdir unittest && cp -rf ./errTemplate/* ./unittest/
|
30
|
+
[ ! -d "./coverageTest" ] && mkdir coverageTest && cp -rf ./errTemplate/* ./coverageTest/
|
31
|
+
[ ! -d "./coverage" ] && mkdir coverage && cp -rf ./errTemplate/* ./coverage/
|
32
|
+
|
33
|
+
tar -czvf $publishFolder.tar.gz coverage screenShots unittest coverageTest commitCoverage ./css ./js ./index.html ./result.json
|
34
|
+
|
35
|
+
curl -i -F name=file -F file=@$publishFolder.tar.gz $url"/cgi-bin/upload.py"
|
36
|
+
replace=$publishFolder
|
37
|
+
reportUrl=$url"/"$replace
|
38
|
+
subject="Client Report - React - $publishFolder"
|
39
|
+
msg="<p><b>Report URL - <a href='$reportUrl'>Link</a></b></p>
|
40
|
+
<p><b>Report Branchname - $branchName</b></p>
|
41
|
+
<p><b>Report Unique ID - $unique</b></p>
|
42
|
+
<p><b>Report Developer - $6</b></p>"
|
43
|
+
#node mailSender.js <from> <pass> <to> <subject> <text>
|
44
|
+
BASEDIR=$(dirname "$0")
|
45
|
+
node $BASEDIR"/../utils/mailSender" $4 $5 $6 "$subject" "$msg" $7 $8 "$reportUrl"
|