@zohodesk/client_build_tool 0.0.6-exp.40 → 0.0.6-exp.42

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/README.md CHANGED
@@ -86,6 +86,154 @@ For more [Details](ConfigurationDocumentation.md)
86
86
 
87
87
 
88
88
 
89
+ **Feature:-**
90
+ - externals was added to Prevent bundling of certain imported packages and retrieve these external dependencies at runtime.
91
+ - to use externals, we use the following pattern in `app > externals` :
92
+
93
+ For example
94
+ ```
95
+ externals: {
96
+ <key> : <value>
97
+ }
98
+ ```
99
+
100
+ ## v0.0.6 (4-09-2023)
101
+
102
+ **Feature:-**
103
+ - Generating bundle integrity report json file for the build assets only in production mode. To use this feature we need to add `stats > enable` or cli flags `enable_stats`.
104
+ - Added Resource Cleanup plugin to cleanup resource retained by build tool. this plugin is controlled by efc flag resourcecleanup flag.
105
+ - added support for using regex expression to get group of chunks chunkId via Resource Hint plugin prefetch/preload hook.
106
+ only will be activate when `resourceHints` => `allowPrefetchingMultipleChunks` as `true`
107
+ - added support for glob pattern for custom chunks split logic.
108
+ - added options to split chunks base config in the key `app` => `customChunksBaseConfig` as object
109
+
110
+ **Change:-**
111
+ - i18n name not generated issue fix.
112
+ - public path not correctly set issue fix.
113
+ - changing plugin hook stages in i18nRuntimePlugin and sourceMapPlugin
114
+ ## v0.0.5 (6-08-2023)
115
+
116
+ **Changes:--**
117
+ - Typo fix in i18nRuntimeDealerPlugin.js
118
+ - fixing some bugs in resolvers.js file
119
+
120
+ ## v0.0.3 (1-08-2023)
121
+
122
+ **Changes:--**
123
+ - `devtool` default value changed from `hidden-cheap-source-map` to `source-map`
124
+ - unwanted files deleted from build
125
+
126
+ **Issue Fix:--**
127
+ - The issue with the source map not being created in the build has been fixed."
128
+
129
+
130
+ ## v0.0.2 (28-04-2023)
131
+
132
+ **Features:-**
133
+
134
+ - `devModeContentHashAllowedTypes` support added for some project there will be a need for hash even though they run dev mode. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#devModeContentHashAllowedTypes)
135
+ - `devLikeHash` support for disable content hash for file names in production mode. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#devLikeHash)
136
+ - `disableReactDevWarning` disable react dev warning such as prop-type warnings will be removed in dev mode build or server. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#disableReactDevWarning) can be enabled via `--disable_react_dev_warning` too.
137
+ - `statsLogConfig` support to customize default webpack log after build finished. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#statsLogConfig) can be enabled via `--disable_react_dev_warning` too.
138
+ - `enableChunkHash` renamed as `enableFileNameHashing`
139
+
140
+ - `pre_processor` command to run the preprocessor.js file.preProcessor runs in build, start, buildEs, buildLib commands bu default. and we have watch mode support as well with the option (`-w`)
141
+ - `createSeparateSmap` flag `source_map_enable` renamed as `enable_smap`
142
+ - `removeAttribute` option changes as `babelCustomizations.removeAttribute`
143
+ - `removePropTypes` support for remove the prop types package in the output build.
144
+ - `devConsoleExclude` support for remove the _console statements_ such as _console.log_, _console.warn_ in the output build.
145
+ - `manifestJson` default value set as false.
146
+ - `customAttributes` support for add attributes to html, link , script tag in the output build.
147
+
148
+
149
+ ## v0.0.1 (18-04-2023)
150
+
151
+ First Release
152
+ **Features:-**
153
+
154
+ - 'start' command to run react app
155
+ - 'build' command to create build for react app
156
+ - 'build:lib' command to create lib for react library
157
+ - 'build:es' command to create es for react library
158
+ - 'templates' command to create es for react library
159
+ # Changelog and Release Notes
160
+
161
+
162
+
163
+ **Feature:-**
164
+ - externals was added to Prevent bundling of certain imported packages and retrieve these external dependencies at runtime.
165
+ - to use externals, we use the following pattern in `app > externals` :
166
+
167
+ For example
168
+ ```
169
+ externals: {
170
+ <key> : <value>
171
+ }
172
+ ```
173
+
174
+ ## v0.0.6 (4-09-2023)
175
+
176
+ **Feature:-**
177
+ - Generating bundle integrity report json file for the build assets only in production mode. To use this feature we need to add `stats > enable` or cli flags `enable_stats`.
178
+ - Added Resource Cleanup plugin to cleanup resource retained by build tool. this plugin is controlled by efc flag resourcecleanup flag.
179
+ - added support for using regex expression to get group of chunks chunkId via Resource Hint plugin prefetch/preload hook.
180
+ only will be activate when `resourceHints` => `allowPrefetchingMultipleChunks` as `true`
181
+ - added support for glob pattern for custom chunks split logic.
182
+ - added options to split chunks base config in the key `app` => `customChunksBaseConfig` as object
183
+
184
+ **Change:-**
185
+ - i18n name not generated issue fix.
186
+ - public path not correctly set issue fix.
187
+ - changing plugin hook stages in i18nRuntimePlugin and sourceMapPlugin
188
+ ## v0.0.5 (6-08-2023)
189
+
190
+ **Changes:--**
191
+ - Typo fix in i18nRuntimeDealerPlugin.js
192
+ - fixing some bugs in resolvers.js file
193
+
194
+ ## v0.0.3 (1-08-2023)
195
+
196
+ **Changes:--**
197
+ - `devtool` default value changed from `hidden-cheap-source-map` to `source-map`
198
+ - unwanted files deleted from build
199
+
200
+ **Issue Fix:--**
201
+ - The issue with the source map not being created in the build has been fixed."
202
+
203
+
204
+ ## v0.0.2 (28-04-2023)
205
+
206
+ **Features:-**
207
+
208
+ - `devModeContentHashAllowedTypes` support added for some project there will be a need for hash even though they run dev mode. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#devModeContentHashAllowedTypes)
209
+ - `devLikeHash` support for disable content hash for file names in production mode. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#devLikeHash)
210
+ - `disableReactDevWarning` disable react dev warning such as prop-type warnings will be removed in dev mode build or server. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#disableReactDevWarning) can be enabled via `--disable_react_dev_warning` too.
211
+ - `statsLogConfig` support to customize default webpack log after build finished. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#statsLogConfig) can be enabled via `--disable_react_dev_warning` too.
212
+ - `enableChunkHash` renamed as `enableFileNameHashing`
213
+
214
+ - `pre_processor` command to run the preprocessor.js file.preProcessor runs in build, start, buildEs, buildLib commands bu default. and we have watch mode support as well with the option (`-w`)
215
+ - `createSeparateSmap` flag `source_map_enable` renamed as `enable_smap`
216
+ - `removeAttribute` option changes as `babelCustomizations.removeAttribute`
217
+ - `removePropTypes` support for remove the prop types package in the output build.
218
+ - `devConsoleExclude` support for remove the _console statements_ such as _console.log_, _console.warn_ in the output build.
219
+ - `manifestJson` default value set as false.
220
+ - `customAttributes` support for add attributes to html, link , script tag in the output build.
221
+
222
+
223
+ ## v0.0.1 (18-04-2023)
224
+
225
+ First Release
226
+ **Features:-**
227
+
228
+ - 'start' command to run react app
229
+ - 'build' command to create build for react app
230
+ - 'build:lib' command to create lib for react library
231
+ - 'build:es' command to create es for react library
232
+ - 'templates' command to create es for react library
233
+ # Changelog and Release Notes
234
+
235
+
236
+
89
237
  **Feature:-**
90
238
  - externals was added to Prevent bundling of certain imported packages and retrieve these external dependencies at runtime.
91
239
  - to use externals, we use the following pattern in `app > externals` :
package/README_backup.md CHANGED
@@ -82,3 +82,151 @@ The following commands are available options for the `cbt` (Client Build Tool) C
82
82
  These commands provide flexibility and control over your client-side build process, allowing you to start the development server, build your application, transpile libraries, create templates, run a mock API server, and more.
83
83
 
84
84
  For more [Details](ConfigurationDocumentation.md)
85
+ # Changelog and Release Notes
86
+
87
+
88
+
89
+ **Feature:-**
90
+ - externals was added to Prevent bundling of certain imported packages and retrieve these external dependencies at runtime.
91
+ - to use externals, we use the following pattern in `app > externals` :
92
+
93
+ For example
94
+ ```
95
+ externals: {
96
+ <key> : <value>
97
+ }
98
+ ```
99
+
100
+ ## v0.0.6 (4-09-2023)
101
+
102
+ **Feature:-**
103
+ - Generating bundle integrity report json file for the build assets only in production mode. To use this feature we need to add `stats > enable` or cli flags `enable_stats`.
104
+ - Added Resource Cleanup plugin to cleanup resource retained by build tool. this plugin is controlled by efc flag resourcecleanup flag.
105
+ - added support for using regex expression to get group of chunks chunkId via Resource Hint plugin prefetch/preload hook.
106
+ only will be activate when `resourceHints` => `allowPrefetchingMultipleChunks` as `true`
107
+ - added support for glob pattern for custom chunks split logic.
108
+ - added options to split chunks base config in the key `app` => `customChunksBaseConfig` as object
109
+
110
+ **Change:-**
111
+ - i18n name not generated issue fix.
112
+ - public path not correctly set issue fix.
113
+ - changing plugin hook stages in i18nRuntimePlugin and sourceMapPlugin
114
+ ## v0.0.5 (6-08-2023)
115
+
116
+ **Changes:--**
117
+ - Typo fix in i18nRuntimeDealerPlugin.js
118
+ - fixing some bugs in resolvers.js file
119
+
120
+ ## v0.0.3 (1-08-2023)
121
+
122
+ **Changes:--**
123
+ - `devtool` default value changed from `hidden-cheap-source-map` to `source-map`
124
+ - unwanted files deleted from build
125
+
126
+ **Issue Fix:--**
127
+ - The issue with the source map not being created in the build has been fixed."
128
+
129
+
130
+ ## v0.0.2 (28-04-2023)
131
+
132
+ **Features:-**
133
+
134
+ - `devModeContentHashAllowedTypes` support added for some project there will be a need for hash even though they run dev mode. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#devModeContentHashAllowedTypes)
135
+ - `devLikeHash` support for disable content hash for file names in production mode. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#devLikeHash)
136
+ - `disableReactDevWarning` disable react dev warning such as prop-type warnings will be removed in dev mode build or server. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#disableReactDevWarning) can be enabled via `--disable_react_dev_warning` too.
137
+ - `statsLogConfig` support to customize default webpack log after build finished. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#statsLogConfig) can be enabled via `--disable_react_dev_warning` too.
138
+ - `enableChunkHash` renamed as `enableFileNameHashing`
139
+
140
+ - `pre_processor` command to run the preprocessor.js file.preProcessor runs in build, start, buildEs, buildLib commands bu default. and we have watch mode support as well with the option (`-w`)
141
+ - `createSeparateSmap` flag `source_map_enable` renamed as `enable_smap`
142
+ - `removeAttribute` option changes as `babelCustomizations.removeAttribute`
143
+ - `removePropTypes` support for remove the prop types package in the output build.
144
+ - `devConsoleExclude` support for remove the _console statements_ such as _console.log_, _console.warn_ in the output build.
145
+ - `manifestJson` default value set as false.
146
+ - `customAttributes` support for add attributes to html, link , script tag in the output build.
147
+
148
+
149
+ ## v0.0.1 (18-04-2023)
150
+
151
+ First Release
152
+ **Features:-**
153
+
154
+ - 'start' command to run react app
155
+ - 'build' command to create build for react app
156
+ - 'build:lib' command to create lib for react library
157
+ - 'build:es' command to create es for react library
158
+ - 'templates' command to create es for react library
159
+ # Changelog and Release Notes
160
+
161
+
162
+
163
+ **Feature:-**
164
+ - externals was added to Prevent bundling of certain imported packages and retrieve these external dependencies at runtime.
165
+ - to use externals, we use the following pattern in `app > externals` :
166
+
167
+ For example
168
+ ```
169
+ externals: {
170
+ <key> : <value>
171
+ }
172
+ ```
173
+
174
+ ## v0.0.6 (4-09-2023)
175
+
176
+ **Feature:-**
177
+ - Generating bundle integrity report json file for the build assets only in production mode. To use this feature we need to add `stats > enable` or cli flags `enable_stats`.
178
+ - Added Resource Cleanup plugin to cleanup resource retained by build tool. this plugin is controlled by efc flag resourcecleanup flag.
179
+ - added support for using regex expression to get group of chunks chunkId via Resource Hint plugin prefetch/preload hook.
180
+ only will be activate when `resourceHints` => `allowPrefetchingMultipleChunks` as `true`
181
+ - added support for glob pattern for custom chunks split logic.
182
+ - added options to split chunks base config in the key `app` => `customChunksBaseConfig` as object
183
+
184
+ **Change:-**
185
+ - i18n name not generated issue fix.
186
+ - public path not correctly set issue fix.
187
+ - changing plugin hook stages in i18nRuntimePlugin and sourceMapPlugin
188
+ ## v0.0.5 (6-08-2023)
189
+
190
+ **Changes:--**
191
+ - Typo fix in i18nRuntimeDealerPlugin.js
192
+ - fixing some bugs in resolvers.js file
193
+
194
+ ## v0.0.3 (1-08-2023)
195
+
196
+ **Changes:--**
197
+ - `devtool` default value changed from `hidden-cheap-source-map` to `source-map`
198
+ - unwanted files deleted from build
199
+
200
+ **Issue Fix:--**
201
+ - The issue with the source map not being created in the build has been fixed."
202
+
203
+
204
+ ## v0.0.2 (28-04-2023)
205
+
206
+ **Features:-**
207
+
208
+ - `devModeContentHashAllowedTypes` support added for some project there will be a need for hash even though they run dev mode. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#devModeContentHashAllowedTypes)
209
+ - `devLikeHash` support for disable content hash for file names in production mode. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#devLikeHash)
210
+ - `disableReactDevWarning` disable react dev warning such as prop-type warnings will be removed in dev mode build or server. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#disableReactDevWarning) can be enabled via `--disable_react_dev_warning` too.
211
+ - `statsLogConfig` support to customize default webpack log after build finished. for details [details](https://zgit.csez.zohocorpin.com/zohodesk/react-cli/-/blob/3.0.0/packages/client_build_tool/ConfigurationDocumentation.md#statsLogConfig) can be enabled via `--disable_react_dev_warning` too.
212
+ - `enableChunkHash` renamed as `enableFileNameHashing`
213
+
214
+ - `pre_processor` command to run the preprocessor.js file.preProcessor runs in build, start, buildEs, buildLib commands bu default. and we have watch mode support as well with the option (`-w`)
215
+ - `createSeparateSmap` flag `source_map_enable` renamed as `enable_smap`
216
+ - `removeAttribute` option changes as `babelCustomizations.removeAttribute`
217
+ - `removePropTypes` support for remove the prop types package in the output build.
218
+ - `devConsoleExclude` support for remove the _console statements_ such as _console.log_, _console.warn_ in the output build.
219
+ - `manifestJson` default value set as false.
220
+ - `customAttributes` support for add attributes to html, link , script tag in the output build.
221
+
222
+
223
+ ## v0.0.1 (18-04-2023)
224
+
225
+ First Release
226
+ **Features:-**
227
+
228
+ - 'start' command to run react app
229
+ - 'build' command to create build for react app
230
+ - 'build:lib' command to create lib for react library
231
+ - 'build:es' command to create es for react library
232
+ - 'templates' command to create es for react library
@@ -340,6 +340,10 @@ var _default = {
340
340
  optimization: {
341
341
  jsExcludePath: '',
342
342
  cssExcludePath: ''
343
+ },
344
+ customScriptLoadingStrategey: {
345
+ enable: false,
346
+ options: null
343
347
  }
344
348
  };
345
349
  exports.default = _default;
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.CustomScriptLoadingStrategyPlugin = void 0;
7
+
8
+ var _htmlWebpackPlugin = _interopRequireDefault(require("html-webpack-plugin"));
9
+
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
+
12
+ const pluginName = 'CustomScriptLoadingStrategyPlugin';
13
+
14
+ class CustomScriptLoadingStrategyPlugin {
15
+ constructor({
16
+ scriptLoadingStategey
17
+ } = {}) {
18
+ this.scriptLoadingStrategy = scriptLoadingStategey;
19
+ this.tagNamesToMatch = ['script'];
20
+ }
21
+
22
+ getFileNameFromTagSrc(src) {
23
+ const fileNameArr = src.split('/');
24
+ return fileNameArr[fileNameArr.length - 1];
25
+ }
26
+
27
+ addAttributestToTag(tag, attributes) {
28
+ tag.attributes = Object.assign({}, tag.attributes, attributes);
29
+ }
30
+
31
+ matchFileName(tag, fileName) {
32
+ return fileName.test(this.getFileNameFromTagSrc(tag.attributes.src));
33
+ }
34
+
35
+ blockingStrategy(tag) {
36
+ delete tag.attributes.defer;
37
+ delete tag.attributes.async;
38
+ }
39
+
40
+ deferStrategy(tag) {
41
+ delete tag.attributes.async;
42
+ }
43
+
44
+ asyncStrategy(tag) {
45
+ delete tag.attributes.defer;
46
+ }
47
+
48
+ moduleStrategy(tag) {
49
+ this.deferStrategy(tag);
50
+ }
51
+
52
+ matchStrategy(scriptLoadingStrategy, tag) {
53
+ if (scriptLoadingStrategy === 'blocking') {
54
+ this.blockingStrategy(tag);
55
+ }
56
+
57
+ if (scriptLoadingStrategy === 'defer') {
58
+ this.deferStrategy(tag);
59
+ }
60
+
61
+ if (scriptLoadingStrategy === 'async') {
62
+ this.asyncStrategy(tag);
63
+ }
64
+
65
+ if (scriptLoadingStrategy === 'module') {
66
+ this.moduleStrategy(tag);
67
+ }
68
+ }
69
+
70
+ matchAndApplyCustomLoadingStrategyToScripts(tags) {
71
+ Object.keys(this.scriptLoadingStrategy).forEach(scriptLoadingStrategy => {
72
+ const filesToMatch = this.scriptLoadingStrategy[scriptLoadingStrategy];
73
+ tags.forEach(tag => {
74
+ if (this.tagNamesToMatch.includes(tag.tagName) && tag.attributes.src) {
75
+ const isFileMatch = filesToMatch.some(fileName => this.matchFileName(tag, fileName));
76
+
77
+ if (isFileMatch) {
78
+ this.matchStrategy(scriptLoadingStrategy, tag);
79
+ this.addAttributestToTag(tag, {
80
+ [scriptLoadingStrategy]: true
81
+ });
82
+ }
83
+ } // filesToMatch.forEach(fileName => {
84
+ // if (!this.matchFileName(tag, fileName)) {
85
+ // return;
86
+ // }
87
+ // this.matchStrategy(scriptLoadingStrategy, tag);
88
+ // this.addAttributestToTag(tag, fileName, {
89
+ // [scriptLoadingStrategy]: true
90
+ // });
91
+ // });
92
+
93
+ });
94
+ });
95
+ }
96
+
97
+ apply(compiler) {
98
+ compiler.hooks.compilation.tap(pluginName, compilation => {
99
+ _htmlWebpackPlugin.default.getHooks(compilation).alterAssetTagGroups.tapAsync(pluginName, (data, callback) => {
100
+ const tags = [...data.bodyTags, ...data.headTags];
101
+ console.log(tags, 'dummy');
102
+ this.matchAndApplyCustomLoadingStrategyToScripts(tags);
103
+ callback(null, data);
104
+ });
105
+ });
106
+ }
107
+
108
+ }
109
+
110
+ exports.CustomScriptLoadingStrategyPlugin = CustomScriptLoadingStrategyPlugin;
@@ -14,7 +14,7 @@ var _nameTemplates = require("../common/nameTemplates");
14
14
  const ImageExtRegex = /\.jpe?g$|\.gif$|\.png|\.webp$/;
15
15
  const FontExtRegex = /\.woff2|\.woff$|\.ttf$|\.eot$/;
16
16
  const SVGExtRegex = /\.svg$/;
17
- const AudioExtRegex = /\.ogg$/;
17
+ const AudioExtRegex = /\.ogg|\.mp3$/;
18
18
  const VideoExtRegex = /\.mp4|\.webm$/;
19
19
 
20
20
  function createAssetLoader({
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.configCustomScriptLoadingStrategyPlugin = configCustomScriptLoadingStrategyPlugin;
7
+
8
+ var _CustomScriptLoadingPlugin = require("../custom_plugins/CustomScriptLoadingPlugin");
9
+
10
+ var _utils = require("../utils");
11
+
12
+ const defaultScriptLoadingStrategy = 'defer';
13
+ const allowedScriptLoadingStrategies = ['blocking', 'defer', 'async', 'module'];
14
+
15
+ function isAllowedScriptLoadingStrategyUsed(scriptLoadingStategey) {
16
+ return allowedScriptLoadingStrategies.includes(scriptLoadingStategey);
17
+ }
18
+
19
+ function getScriptLoadingStrategyForStringType(scriptLoadingStategey) {
20
+ if (isAllowedScriptLoadingStrategyUsed(scriptLoadingStategey)) {
21
+ return scriptLoadingStategey;
22
+ }
23
+
24
+ return defaultScriptLoadingStrategy;
25
+ }
26
+
27
+ function getScriptLoadingStrategyForObject(scriptLoadingStategey) {
28
+ if (Object.keys(scriptLoadingStategey).length === 0) {
29
+ return defaultScriptLoadingStrategy;
30
+ }
31
+
32
+ const isAllowedScriptLoadingStrategy = Object.keys(scriptLoadingStategey).every(key => isAllowedScriptLoadingStrategyUsed(key));
33
+
34
+ if (isAllowedScriptLoadingStrategy) {
35
+ return Object.assign({}, scriptLoadingStategey);
36
+ }
37
+
38
+ console.warn('un supported script loading strategy used', scriptLoadingStategey);
39
+ return defaultScriptLoadingStrategy;
40
+ }
41
+
42
+ function getScriptLoadingStrategy(scriptLoadingStategey) {
43
+ if ((0, _utils.getTypeOf)(scriptLoadingStategey) === 'string') {
44
+ return {
45
+ [getScriptLoadingStrategyForStringType(scriptLoadingStategey)]: [/.*/]
46
+ };
47
+ }
48
+
49
+ if ((0, _utils.getTypeOf)(scriptLoadingStategey) === 'object') {
50
+ return getScriptLoadingStrategyForObject(scriptLoadingStategey);
51
+ }
52
+
53
+ return {
54
+ [defaultScriptLoadingStrategy]: [/.*/]
55
+ };
56
+ }
57
+
58
+ function configCustomScriptLoadingStrategyPlugin(options) {
59
+ const {
60
+ customScriptLoadingStrategey
61
+ } = options;
62
+
63
+ if (customScriptLoadingStrategey) {
64
+ const currentScriptLoadingStrategy = getScriptLoadingStrategy(customScriptLoadingStrategey.options);
65
+
66
+ if ((0, _utils.getTypeOf)(currentScriptLoadingStrategy) === 'object') {
67
+ return new _CustomScriptLoadingPlugin.CustomScriptLoadingStrategyPlugin({
68
+ scriptLoadingStategey: currentScriptLoadingStrategy
69
+ });
70
+ } else {
71
+ return null;
72
+ }
73
+ } else {
74
+ return null;
75
+ }
76
+ }
@@ -47,10 +47,12 @@ var _configBundleIntegrityReport = require("./pluginConfigs/configBundleIntegrit
47
47
 
48
48
  var _configRuntimeResourceCleanup = require("./pluginConfigs/configRuntimeResourceCleanup");
49
49
 
50
+ var _configCustomScriptLoadingStrategyPlugin = require("./pluginConfigs/configCustomScriptLoadingStrategyPlugin");
51
+
50
52
  // import { IgnorePlugin } from 'webpack';
51
53
  function plugins(options) {
52
54
  const {
53
55
  webpackPlugins
54
56
  } = options;
55
- return [(0, _configEnvVariables.configEnvVariables)(options), (0, _configCustomAttributesPlugin.configCustomAttributesPlugin)(options), (0, _configTPHashMappingPlugin.configTPHashMappingPlugin)(options), (0, _configCopyPublicFolders.configCopyPublicFolders)(options), (0, _configIgnorePlugin.configIgnorePlugin)(options), (0, _configMiniCSSExtractPlugin.configMiniCSSExtractPlugin)(options), (0, _configSelectorWeightPlugin.configSelectorWeightPlugin)(options), (0, _configVariableConversionPlugin.configVariableConversionPlugin)(options), (0, _configI18nSplitPlugin.configI18nSplitPlugin)(options), (0, _configRtlCssPlugin.configRtlCssPlugin)(options), (0, _configHtmlWebpackPlugin.configHtmlWebpackPlugin)(options), (0, _configCdnChangePlugin.configCdnChangePlugin)(options), (0, _configServiceWorkerPlugin.configServiceWorkerPlugin)(options), (0, _configEFCTemplatePlugin.configEFCTemplatePlugin)(options), (0, _configResourceHintsPlugin.configResourceHintsPlugin)(options), (0, _configBundleAnalyzer.configBundleAnalyzer)(options), (0, _configManifestJsonPlugin.configManifestJsonPlugin)(options), (0, _configSourceMapPlugin.configSourceMapPlugin)(options), (0, _configProgressPlugin.configProgressPlugin)(options), (0, _configBundleIntegrityReport.configBundleIntegrityReport)(options), (0, _configRuntimeResourceCleanup.configRuntimeResourceCleanup)(options), ...webpackPlugins].filter(Boolean);
57
+ return [(0, _configEnvVariables.configEnvVariables)(options), (0, _configCustomAttributesPlugin.configCustomAttributesPlugin)(options), (0, _configTPHashMappingPlugin.configTPHashMappingPlugin)(options), (0, _configCopyPublicFolders.configCopyPublicFolders)(options), (0, _configIgnorePlugin.configIgnorePlugin)(options), (0, _configMiniCSSExtractPlugin.configMiniCSSExtractPlugin)(options), (0, _configSelectorWeightPlugin.configSelectorWeightPlugin)(options), (0, _configVariableConversionPlugin.configVariableConversionPlugin)(options), (0, _configI18nSplitPlugin.configI18nSplitPlugin)(options), (0, _configRtlCssPlugin.configRtlCssPlugin)(options), (0, _configHtmlWebpackPlugin.configHtmlWebpackPlugin)(options), (0, _configCustomScriptLoadingStrategyPlugin.configCustomScriptLoadingStrategyPlugin)(options), (0, _configCdnChangePlugin.configCdnChangePlugin)(options), (0, _configServiceWorkerPlugin.configServiceWorkerPlugin)(options), (0, _configEFCTemplatePlugin.configEFCTemplatePlugin)(options), (0, _configResourceHintsPlugin.configResourceHintsPlugin)(options), (0, _configBundleAnalyzer.configBundleAnalyzer)(options), (0, _configManifestJsonPlugin.configManifestJsonPlugin)(options), (0, _configSourceMapPlugin.configSourceMapPlugin)(options), (0, _configProgressPlugin.configProgressPlugin)(options), (0, _configBundleIntegrityReport.configBundleIntegrityReport)(options), (0, _configRuntimeResourceCleanup.configRuntimeResourceCleanup)(options), ...webpackPlugins].filter(Boolean);
56
58
  }
@@ -3,6 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
+ exports.getTypeOf = getTypeOf;
6
7
  exports.isJsFile = exports.isDirRelatedCss = exports.isCssFile = exports.isCss = void 0;
7
8
 
8
9
  var _path = _interopRequireDefault(require("path"));
@@ -23,4 +24,8 @@ exports.isJsFile = isJsFile;
23
24
 
24
25
  const isCssFile = file => /\.css$/.test(file);
25
26
 
26
- exports.isCssFile = isCssFile;
27
+ exports.isCssFile = isCssFile;
28
+
29
+ function getTypeOf(value) {
30
+ return Object.prototype.toString.call(value).split(/\s/)[1].replace(/\]/, '').toLowerCase();
31
+ }
@@ -306,7 +306,7 @@ var _default = ({
306
306
  range
307
307
  } = settings;
308
308
  const convertedVals = valArr.map(val => {
309
- if (val.includes('px')) {
309
+ if (val.includes('px') && val.toString() !== '0') {
310
310
  const convertedVal = singleConvertor(val, settings.replacements.px, {
311
311
  decl,
312
312
  filename,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zohodesk/client_build_tool",
3
- "version": "0.0.6-exp.40",
3
+ "version": "0.0.6-exp.42",
4
4
  "description": "A CLI tool to build web applications and client libraries",
5
5
  "main": "lib/index.js",
6
6
  "bin": {