@zohodesk/react-cli 1.1.27-exp.1 → 1.1.27-exp.3
Sign up to get free protection for your applications and to get access to all the features.
- package/lib/configs/jest.config.js +1 -1
- package/lib/configs/libAlias.js +2 -2
- package/lib/configs/resolvers.js +2 -2
- package/lib/schemas/index.js +1 -0
- package/npm-shrinkwrap.json +4 -4
- package/package.json +1 -1
- package/packages/client_build_tool/lib/allCommandsConfigs.js +25 -0
- package/packages/client_build_tool/lib/commands/build/commandExecutor.js +17 -0
- package/packages/client_build_tool/lib/commands/build/config.js +12 -0
- package/packages/client_build_tool/lib/commands/build/optionsProcessor.js +35 -0
- package/packages/client_build_tool/lib/commands/build/preProcessor.js +12 -0
- package/packages/client_build_tool/lib/commands/buildEs/commandExecutor.js +33 -0
- package/packages/client_build_tool/lib/commands/buildEs/config.js +12 -0
- package/packages/client_build_tool/lib/commands/buildEs/preProcessor.js +17 -0
- package/packages/client_build_tool/lib/commands/buildLib/commandExecutor.js +33 -0
- package/packages/client_build_tool/lib/commands/buildLib/config.js +12 -0
- package/packages/client_build_tool/lib/commands/buildLib/preProcessor.js +17 -0
- package/packages/client_build_tool/lib/commands/mockserver/commandExecutor.js +43 -0
- package/packages/client_build_tool/lib/commands/mockserver/config.js +12 -0
- package/packages/client_build_tool/lib/commands/pre_process/commandExecutor.js +18 -0
- package/packages/client_build_tool/lib/commands/pre_process/config.js +12 -0
- package/packages/client_build_tool/lib/commands/start/commandExecutor.js +12 -0
- package/packages/client_build_tool/lib/commands/start/config.js +12 -0
- package/packages/client_build_tool/lib/commands/start/optionsProcessor.js +30 -0
- package/packages/client_build_tool/lib/commands/start/preProcessor.js +12 -0
- package/packages/client_build_tool/lib/commands/template/commandExecutor.js +28 -0
- package/packages/client_build_tool/lib/commands/template/config.js +12 -0
- package/packages/client_build_tool/lib/commands/version/commandExecutor.js +14 -0
- package/packages/client_build_tool/lib/commands/version/config.js +12 -0
- package/packages/client_build_tool/lib/commandsRouter.js +74 -0
- package/packages/client_build_tool/lib/index.js +12 -0
- package/packages/client_build_tool/lib/logger.js +34 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/otherTestCases.test.js +234 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/passingDifferentDataTypesToSchema.test.js +103 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/passingEmptyObjects.test.js +41 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByCustomOptions/convertArray.test.js +68 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByCustomOptions/convertNumber.test.js +68 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByCustomOptions/convertObject.test.js +141 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByCustomOptions/convertString.test.js +68 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByCustomOptions/convertUndefinedAndNull.test.js +132 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByProcessEnv/convertArray.test.js +71 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByProcessEnv/convertNumber.test.js +71 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByProcessEnv/convertObject.test.js +73 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByProcessEnv/convertString.test.js +71 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/__test__/replacingSchemaValueByProcessEnv/convertUndefinedAndNull.test.js +138 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/index.js +34 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/isObject.js +10 -0
- package/packages/client_build_tool/lib/schemas/applyValuesToSchema/isValid.js +14 -0
- package/packages/client_build_tool/lib/schemas/cliArgsToObject.js +39 -0
- package/packages/client_build_tool/lib/schemas/defaultConfigValues.js +349 -0
- package/packages/client_build_tool/lib/schemas/defaultConfigValuesOnly.js +187 -0
- package/packages/client_build_tool/lib/schemas/deprecatedOptionsHandler.js +67 -0
- package/packages/client_build_tool/lib/schemas/getNpmVersion.js +22 -0
- package/packages/client_build_tool/lib/schemas/giveDefaultValue.js +18 -0
- package/packages/client_build_tool/lib/schemas/npmConfigToObject.js +35 -0
- package/packages/client_build_tool/lib/schemas/readOptions.js +54 -0
- package/packages/client_build_tool/lib/schemas/readOptionsForConfigFile.js +42 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/Map.test.js +15 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/MathAndNumberMethod.test.js +30 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/ObjectAndModules.test.js +47 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/Sets.test.js +18 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/Symbol.test.js +25 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/arrowFunction.test.js +34 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/block-scoping.test.js +18 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/classes.test.js +55 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/defaultParameterValues.test.js +18 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/extraFeatures.test.js +82 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/forOf.test.js +20 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/promise.test.js +22 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/spreadOperator.test.js +20 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/spreadParams.test.js +24 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/stringAndArrayMethods.test.js +67 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2015/variables.test.js +21 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2016/array-includes.test.js +13 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2016/exponentationOperator.test.js +20 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2017/asyncAndawait.test.js +23 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2017/object-entries.test.js +24 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2017/object-getOwnproperties.test.js +24 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2017/object-values.test.js +24 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2017/stringMethods.test.js +20 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2018/asynchronous-iterator.test.js +19 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2018/object-rest-spread.test.js +24 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2018/promise-finally.test.js +26 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2018/regularExpressions.test.js +35 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2019/Json.stringify.test.js +21 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2019/arrayMethods.test.js +31 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2019/object-fromEntriesMethod.test.js +13 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2019/optionalCatchBinding.test.js +23 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2019/revisedFunctionToString.test.js +17 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2019/trim-startAndend-method.test.js +20 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2020/AssignmentOperator.test.js +27 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2020/Dynamic-Import.test.js +19 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2020/NullishOperator.test.js +15 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2020/bigInt.test.js +13 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2020/chainOperator.test.js +17 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2020/export-namespace-from.test.js +12 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2020/promiseAllSettledMathod.test.js +17 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2020/stringMatchMethod.test.js +13 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2021/NumericSeparator.test.js +23 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2021/logicalOperatorAssignments.test.js +25 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2021/promiseAny.test.js +16 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2021/stringReplaceMethod.test.js +16 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/Array-atMethod.test.js +13 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/ObjectKeyCheck.test.js +27 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/ObjecthasOwnMethod.test.js +19 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/RegexMatchIndices.test.js +20 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/String-atMethod.test.js +15 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/error.Cause.test.js +23 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/keysCheckinPrivateFields.test.js +27 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/privateMethodsAndFields.test.js +23 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/staticFieldsAndMethod.test.js +54 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/topLevelAwait.test.js +11 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/es2022/weakRef.test.js +17 -0
- package/packages/client_build_tool/lib/shared/babel/__test__/utilities.js +28 -0
- package/packages/client_build_tool/lib/shared/babel/addDefaultPlugins.js +15 -0
- package/packages/client_build_tool/lib/shared/babel/babelWebConfig.js +54 -0
- package/packages/client_build_tool/lib/shared/babel/babel_plugins/removeAttributesPlugin.js +23 -0
- package/packages/client_build_tool/lib/shared/babel/getBabelPlugin.js +37 -0
- package/packages/client_build_tool/lib/shared/babel/runBabelForJSFile.js +24 -0
- package/packages/client_build_tool/lib/shared/babel/runBabelForTsFile.js +30 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/common/decidePublicPath.js +57 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/common/libAlias.js +31 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/common/modeUtils.js +39 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/common/nameTemplates.js +105 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/common/resourceBasedPublicPath.js +21 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/configCustomLoaders.js +10 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/cssLoaders.js +16 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/BundleIntegrityReport/index.js +83 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/CdnChangePlugin/index.js +119 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/CdnChangePlugin/webpackCustomJsUrlLoader.js +46 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/CustomScriptLoadingPlugin.js +109 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/EFCTemplatePlugin.js +112 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/ContributionGuide.md +11 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/I18nFilesEmitPlugin.js +174 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/I18nKeysIdentifer.js +76 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/I18nRuntimeDealerPlugin.js +223 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/I18nSplit.md +95 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/LocaleChunkAssetsStore.js +73 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/ModulesI18nKeysStore.js +88 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/README.md +25 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/constants.js +29 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/createHash.js +24 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/getI18nLoadingRuntimeModule.js +76 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/index.js +39 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/iterateModulesInChunk.js +50 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/optionsHandler.js +68 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/pathCreator.js +23 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/readI18nValues.js +29 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/templateFileName.js +43 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/templateHashHelpers.js +77 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/classesAndObject.test.js +56 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/conditionalOperation.test.js +154 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/function.test.js +89 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/function2.test.js +71 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/loop.test.js +112 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/minifyBooleanValues.test.js +43 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/minimizeVariableNames.test.js +45 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/promise.test.js +53 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/removeCommentsAndEmptySpace.test.js +13 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/removeUnusedStrings.test.js +14 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/terser/__test__/variableDeclaration.test.js +30 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/utils/collectI18nKeys.js +66 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/utils/getChunkModules.js +13 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/utils/hashUtils.js +19 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/utils/index.js +31 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/I18nSplitPlugin/utils/propertiesUtils.js +129 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/InitialHtmlPlugin.js +60 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ManifestJsonPlugin/__test__/addFilesNamesToManifestJson.test.js +51 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ManifestJsonPlugin/__test__/createInitialEntries.test.js +95 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ManifestJsonPlugin/__test__/removeHashFromFileName.test.js +91 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ManifestJsonPlugin/addFilesNamesToManifestJson.js +30 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ManifestJsonPlugin/createInitialEntries.js +23 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ManifestJsonPlugin/createManifestJson.js +35 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ManifestJsonPlugin/findInitialFileNames.js +18 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ManifestJsonPlugin/index.js +46 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ManifestJsonPlugin/removeHashFromFileName.js +18 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/RTLSplitPlugin.js +1 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ResourceHintsPlugin.js +193 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/RtlSplitPlugin/OverwriteCssPathForRTL.js +62 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/RtlSplitPlugin/RtlCssPlugin.js +84 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/RtlSplitPlugin/RtrSplit.md +34 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/RtlSplitPlugin/replaceCssDirTemplate.js +27 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/RuntimeResourceCleanup/index.js +73 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/SelectorWeightPlugin/classHandling.js +20 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/SelectorWeightPlugin/index.js +78 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/SelectorWeightPlugin/selectorWeightPrefixAdder.js +51 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/SelectorWeightPlugin/windowsModification.js +16 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ServiceWorkerPlugin.js +114 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/ServiceWorkerPluginUtils.js +13 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/SourceMapPlugin/index.js +68 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/TPHashMappingPlugin/addHashToFilePath.js +22 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/TPHashMappingPlugin/index.js +55 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/UglifyCSSPlugin/__test__/uglifyCss1.test.js +74 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/UglifyCSSPlugin/__test__/uglifycss.test.js +64 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/UglifyCSSPlugin/__test__/utilities.js +28 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/UglifyCSSPlugin/index.js.js +49 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/VariableConversionCollector/ErrorHandler.js +62 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/VariableConversionCollector/index.js +362 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/custom_attribute_plugin/index.js +80 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/emitAsset.js +14 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/getInitialAssetsFuncTemplate.js +57 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/getInitialI18nAssetsArrayStr.js +87 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/classesAndObject.test.js +56 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/conditionalOperation.test.js +154 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/function.test.js +89 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/function2.test.js +71 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/loop.test.js +112 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/minifyBooleanValues.test.js +43 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/minimizeVariableNames.test.js +45 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/promise.test.js +53 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/removeCommentsAndEmptySpace.test.js +13 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/removeUnusedStrings.test.js +14 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/custom_plugins/terser/__test__/variableDeclaration.test.js +30 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/defaultVendorPatternList.js +13 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/devtoolConfig.js +13 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/entryConfig.js +28 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/externals.js +17 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/getCSSLoaders.js +29 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/getFilenameFromModule.js +24 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/jsLoaders.js +17 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaderConfigs/assetLoaders.js +12 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaderConfigs/babelLoaderConfig.js +18 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaderConfigs/checkIsPatternsMatchFilename.js +56 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaderConfigs/configHtmlTemplateLoader.js +18 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaderConfigs/configPostCssLoader.js +37 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaderConfigs/configWebWorkerLoader.js +21 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaderConfigs/configsAssetsLoaders.js +86 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaderConfigs/cssClassNameGenerate.js +65 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaderConfigs/getCssLoaderOptions.js +21 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaders/miniCssFallBackLoader.js +7 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/loaders/workerLoader.js +133 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/optimizationConfig.js +56 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/outputConfig.js +38 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configBundleAnalyzer.js +40 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configBundleIntegrityReport.js +36 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configCSSMinifierPlugin.js +28 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configCdnChangePlugin.js +27 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configCopyPublicFolders.js +63 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configCustomAttributesPlugin.js +20 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configCustomScriptLoadingStrategyPlugin.js +76 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configEFCTemplatePlugin.js +46 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configEnvVariables.js +51 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configHtmlWebpackPlugin.js +56 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configI18nSplitPlugin.js +41 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configIgnorePlugin.js +16 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configManifestJsonPlugin.js +44 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configMiniCSSExtractPlugin.js +24 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configProgressPlugin.js +24 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configResourceHintsPlugin.js +21 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configRtlCssPlugin.js +27 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configRuntimeResourceCleanup.js +31 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configSelectorWeightPlugin.js +28 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configServiceWorkerPlugin.js +40 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configSourceMapPlugin.js +20 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configTPHashMappingPlugin.js +32 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/pluginConfigs/configVariableConversionPlugin.js +25 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/plugins.js +58 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/resolvers.js +82 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/splitChunksConfig.js +116 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/statsConfig.js +30 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/tsLoaders.js +17 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/utils/__test__/getArrayWithDefaultWithCustomEqual.test.js +54 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/utils/__test__/updateArrayWithDefault.test.js +47 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/utils/index.js +31 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/utils/object-manipulation.js +87 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/utils/updateArrayWithDefault.js +34 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/webpackBuild.js +27 -0
- package/packages/client_build_tool/lib/shared/bundler/webpack/webpackConfig.js +58 -0
- package/packages/client_build_tool/lib/shared/commands-utils/doBasicRequirementCheck.js +17 -0
- package/packages/client_build_tool/lib/shared/commands-utils/getCliPath.js +39 -0
- package/packages/client_build_tool/lib/shared/commands-utils/index.js +29 -0
- package/packages/client_build_tool/lib/shared/commands-utils/log.js +13 -0
- package/packages/client_build_tool/lib/shared/commands-utils/readArgsFormCommandLine.js +11 -0
- package/packages/client_build_tool/lib/shared/commands-utils/readOptionFormCommandLine.js +11 -0
- package/packages/client_build_tool/lib/shared/commands-utils/spawnSyncIO.js +38 -0
- package/packages/client_build_tool/lib/shared/constants.js +48 -0
- package/packages/client_build_tool/lib/shared/fileUtils/copyFile.js +38 -0
- package/packages/client_build_tool/lib/shared/fileUtils/directoryIterator.js +21 -0
- package/packages/client_build_tool/lib/shared/fileUtils/watchRun.js +112 -0
- package/packages/client_build_tool/lib/shared/postcss/__test__/ignoreTestCases.test.js +80 -0
- package/packages/client_build_tool/lib/shared/postcss/__test__/postcss-rtl-all-cases.test.js +119 -0
- package/packages/client_build_tool/lib/shared/postcss/__test__/postcssRtl.spec.js +34 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/EmptyPlugin.js +21 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/HoverActivePlugin/constants.js +10 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/HoverActivePlugin/handleIgnores.js +66 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/HoverActivePlugin/index.js +136 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/HoverActivePlugin/insertBefore.js +32 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/HoverActivePlugin/isPreviouslyProcessed.js +20 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/HoverActivePlugin/replaceUtils.js +20 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/HoverActivePlugin/separateHoveredSelectorAndNormalSelector.js +24 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/HoverActivePlugin/specialCases.js +43 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/HoverActivePlugin/typeCheckUtils.js +52 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/RTLSplitPlugin.js +139 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/SelectorReplace.js +90 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/ValueReplacer.js +57 -0
- package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/VariableModificationPlugin/index.js +347 -0
- package/packages/client_build_tool/lib/shared/postcss/filterPluginsAllowedForSpecficFile.js +55 -0
- package/packages/client_build_tool/lib/shared/postcss/getAllowedPostCssPlugins.js +30 -0
- package/packages/client_build_tool/lib/shared/postcss/getSpecificPostCssPlugin.js +58 -0
- package/packages/client_build_tool/lib/shared/postcss/runPostCssForCssFile.js +37 -0
- package/packages/client_build_tool/lib/shared/pre_process/runPreProcess.js +58 -0
- package/packages/client_build_tool/lib/shared/server/configWebpackDevMiddleware.js +41 -0
- package/packages/client_build_tool/lib/shared/server/corsHandling.js +30 -0
- package/packages/client_build_tool/lib/shared/server/getIp.js +30 -0
- package/packages/client_build_tool/lib/shared/server/getServerURL.js +36 -0
- package/packages/client_build_tool/lib/shared/server/httpsOptions.js +46 -0
- package/packages/client_build_tool/lib/shared/server/initExpressApp.js +19 -0
- package/packages/client_build_tool/lib/shared/server/initialHTMLHandling.js +99 -0
- package/packages/client_build_tool/lib/shared/server/mockApiHandler.js +60 -0
- package/packages/client_build_tool/lib/shared/server/mockServer.js +41 -0
- package/packages/client_build_tool/lib/shared/server/serveContextFiles.js +27 -0
- package/packages/client_build_tool/lib/shared/server/serverBywebpackDevMiddleware.js +35 -0
- package/packages/client_build_tool/lib/shared/server/startHttpServer.js +26 -0
- package/packages/client_build_tool/lib/shared/server/startHttpsServer.js +38 -0
- package/packages/client_build_tool/lib/shared/server/unwanted/addHttp2Server.js +41 -0
- package/packages/client_build_tool/lib/shared/server/unwanted/configWebpackDevMiddleware.js +44 -0
- package/packages/client_build_tool/lib/shared/server/unwanted/mockApiSupport.js +19 -0
- package/packages/client_build_tool/lib/shared/server/unwanted/websocketMockSetup.js +48 -0
- package/packages/client_build_tool/lib/shared/server/urlConcat.js +32 -0
- package/packages/client_build_tool/lib/shared/utils/requireLocalOrGlobal.js +81 -0
- package/packages/client_build_tool/lib/shared/utils/utils.js +1 -0
- package/packages/client_build_tool/lib/shared/utils/versionPrint.js +20 -0
- package/packages/client_build_tool/node_modules/history/CHANGES.md +395 -0
- package/packages/client_build_tool/node_modules/history/DOMUtils.js +3 -0
- package/packages/client_build_tool/node_modules/history/ExecutionEnvironment.js +3 -0
- package/packages/client_build_tool/node_modules/history/LICENSE +21 -0
- package/packages/client_build_tool/node_modules/history/LocationUtils.js +3 -0
- package/packages/client_build_tool/node_modules/history/PathUtils.js +3 -0
- package/packages/client_build_tool/node_modules/history/README.md +282 -0
- package/packages/client_build_tool/node_modules/history/cjs/history.js +933 -0
- package/packages/client_build_tool/node_modules/history/cjs/history.min.js +1 -0
- package/packages/client_build_tool/node_modules/history/createBrowserHistory.js +3 -0
- package/packages/client_build_tool/node_modules/history/createHashHistory.js +3 -0
- package/packages/client_build_tool/node_modules/history/createMemoryHistory.js +3 -0
- package/packages/client_build_tool/node_modules/history/createTransitionManager.js +3 -0
- package/packages/client_build_tool/node_modules/history/es/DOMUtils.js +7 -0
- package/packages/client_build_tool/node_modules/history/es/ExecutionEnvironment.js +7 -0
- package/packages/client_build_tool/node_modules/history/es/LocationUtils.js +7 -0
- package/packages/client_build_tool/node_modules/history/es/PathUtils.js +7 -0
- package/packages/client_build_tool/node_modules/history/es/createBrowserHistory.js +7 -0
- package/packages/client_build_tool/node_modules/history/es/createHashHistory.js +7 -0
- package/packages/client_build_tool/node_modules/history/es/createMemoryHistory.js +7 -0
- package/packages/client_build_tool/node_modules/history/es/createTransitionManager.js +7 -0
- package/packages/client_build_tool/node_modules/history/es/warnAboutDeprecatedESMImport.js +35 -0
- package/packages/client_build_tool/node_modules/history/esm/history.js +904 -0
- package/packages/client_build_tool/node_modules/history/index.js +7 -0
- package/packages/client_build_tool/node_modules/history/package.json +120 -0
- package/packages/client_build_tool/node_modules/history/umd/history.js +1059 -0
- package/packages/client_build_tool/node_modules/history/umd/history.min.js +1 -0
- package/packages/client_build_tool/node_modules/history/warnAboutDeprecatedCJSRequire.js +35 -0
package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/RTLSplitPlugin.js
ADDED
@@ -0,0 +1,139 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.separateRtlAndLtr = separateRtlAndLtr;
|
7
|
+
exports.separateSingleDir = separateSingleDir;
|
8
|
+
|
9
|
+
var postcss = _interopRequireWildcard(require("postcss"));
|
10
|
+
|
11
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
12
|
+
|
13
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
14
|
+
|
15
|
+
/* eslint-disable no-param-reassign */
|
16
|
+
const oppositeDir = {
|
17
|
+
ltr: 'rtl',
|
18
|
+
rtl: 'ltr'
|
19
|
+
};
|
20
|
+
|
21
|
+
function compareSelector(selector1, selector2) {
|
22
|
+
// console.log({ selector1, selector2 }, selector1 === selector2);
|
23
|
+
return selector1 === selector2;
|
24
|
+
}
|
25
|
+
|
26
|
+
const directionRegexs = {
|
27
|
+
ltr: /\[dir=ltr\]/,
|
28
|
+
rtl: /\[dir=rtl\]/
|
29
|
+
};
|
30
|
+
|
31
|
+
const getRegex = dir => directionRegexs[dir];
|
32
|
+
|
33
|
+
const getOppositeRegex = dir => getRegex(oppositeDir[dir]);
|
34
|
+
|
35
|
+
function selectorMinifySameDir(selector, direction) {
|
36
|
+
// NOTE: if this rule is same dir as current need
|
37
|
+
// then we can just remove that [dir=ltr] or [dir=rtl]
|
38
|
+
// it just for minimaze selector
|
39
|
+
const regex = getRegex(direction);
|
40
|
+
return selector.replace(regex, '').trim();
|
41
|
+
}
|
42
|
+
/**
|
43
|
+
* this funtion will remove given rule,
|
44
|
+
* if given selector and it's previous sibiling rule selector are same
|
45
|
+
* current rule properties will move to previous sibiling rule.
|
46
|
+
* @param {Rule} rule current rule
|
47
|
+
*/
|
48
|
+
|
49
|
+
|
50
|
+
function mergeIfSameSelector(rule) {
|
51
|
+
// NOTE: to merge dublicate selector rules
|
52
|
+
const prev = rule.prev();
|
53
|
+
|
54
|
+
if (prev && compareSelector(prev.selector, rule.selector)) {
|
55
|
+
rule.each(decl => {
|
56
|
+
prev.append(decl);
|
57
|
+
});
|
58
|
+
rule.remove();
|
59
|
+
}
|
60
|
+
}
|
61
|
+
/**
|
62
|
+
* this funtion will remove given rule,
|
63
|
+
* if given selector and it's previous sibiling rule selector are same
|
64
|
+
* current rule properties will move to previous sibiling rule.
|
65
|
+
* @param {Rule} rule current rule
|
66
|
+
*/
|
67
|
+
|
68
|
+
|
69
|
+
function removeIfOppsiteDirRule(rule, direction, rootOptions) {
|
70
|
+
// console.log({ rule, type: rule.type });
|
71
|
+
const selectors = rule.selector.split(/\s*,\s*/); // NOTE: if we use opposite dir selector as custom override reason,
|
72
|
+
// and compain normal selector with it, In this case
|
73
|
+
// we just a have to remove that selector only not full rule
|
74
|
+
|
75
|
+
const oppositeDirRegex = getOppositeRegex(direction);
|
76
|
+
let remainingSelectors = selectors.filter(selector => !oppositeDirRegex.test(selector));
|
77
|
+
|
78
|
+
if (!rootOptions.disableMinifySelector) {
|
79
|
+
remainingSelectors = remainingSelectors.map(selector => selectorMinifySameDir(selector, direction));
|
80
|
+
}
|
81
|
+
|
82
|
+
if (remainingSelectors.length) {
|
83
|
+
rule.selector = remainingSelectors.join(', ');
|
84
|
+
} else {
|
85
|
+
// NOTE: every selector is opposite dir then we have to remove the rule
|
86
|
+
rule.remove();
|
87
|
+
}
|
88
|
+
}
|
89
|
+
|
90
|
+
function removeIfOppsiteDirKeyframe(rule, direction) {
|
91
|
+
const name = rule.params;
|
92
|
+
const keyFrameDirName = name.slice(name.lastIndexOf('-') + 1);
|
93
|
+
|
94
|
+
if (keyFrameDirName === oppositeDir[direction]) {
|
95
|
+
// console.log({ m: 'removed', keyFrameName: rule.params });
|
96
|
+
rule.remove();
|
97
|
+
}
|
98
|
+
}
|
99
|
+
|
100
|
+
function separateSingleDir(root, direction, rootOptions) {
|
101
|
+
root.walkRules(rule => {
|
102
|
+
removeIfOppsiteDirRule(rule, direction, rootOptions);
|
103
|
+
mergeIfSameSelector(rule);
|
104
|
+
});
|
105
|
+
root.walkAtRules(rule => {
|
106
|
+
removeIfOppsiteDirKeyframe(rule, direction);
|
107
|
+
});
|
108
|
+
return root;
|
109
|
+
}
|
110
|
+
|
111
|
+
function separateRtlAndLtr(css, rootOptions) {
|
112
|
+
// let processor = postcss([]).process(css);
|
113
|
+
const root = postcss.parse(css); // let { root } = processor;
|
114
|
+
// console.log(processor, root);
|
115
|
+
// NOTE: I did first rtl then ltr , Because for ltr I use original root ref
|
116
|
+
|
117
|
+
const rtlRoot = separateSingleDir(root.clone(), 'rtl', rootOptions); // console.log('############################');
|
118
|
+
|
119
|
+
const ltrRoot = separateSingleDir(root, 'ltr', rootOptions);
|
120
|
+
return {
|
121
|
+
ltrRoot,
|
122
|
+
rtlRoot,
|
123
|
+
ltr: ltrRoot.toString(),
|
124
|
+
rtl: rtlRoot.toString()
|
125
|
+
};
|
126
|
+
} // NOTE: to test in https://astexplorer.net/
|
127
|
+
// you can test with sample input https://astexplorer.net/#/gist/a892a509eb585099355ef53ef094f836/1ca70d5f7af3b88ca4910296e12f118e9712c874
|
128
|
+
// export default postcss.plugin('postcss-rtl-remove', (options = {}) =>
|
129
|
+
// // Work with options here
|
130
|
+
// root => {
|
131
|
+
// const rtlRoot = separateSingleDir(root.clone(), 'rtl');
|
132
|
+
// const ltrRoot = separateSingleDir(root, 'ltr');
|
133
|
+
// // root.append(postcss.comment({ text: 'comment' }));
|
134
|
+
// root.append(postcss.comment({ text: 'this is spliting part ' }));
|
135
|
+
// root.append(rtlRoot);
|
136
|
+
// //console.log({root, roots:root+""}, root+"")
|
137
|
+
// // Transform CSS AST here
|
138
|
+
// }
|
139
|
+
// );
|
package/packages/client_build_tool/lib/shared/postcss/custom_postcss_plugins/SelectorReplace.js
ADDED
@@ -0,0 +1,90 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.default = void 0;
|
7
|
+
|
8
|
+
/* eslint-disable no-param-reassign */
|
9
|
+
var _default = (opts = {}) => {
|
10
|
+
// eslint-disable-next-line no-use-before-define
|
11
|
+
validator(opts);
|
12
|
+
const {
|
13
|
+
before,
|
14
|
+
after
|
15
|
+
} = opts;
|
16
|
+
return {
|
17
|
+
postcssPlugin: 'postcss-selector-replace',
|
18
|
+
|
19
|
+
Once(root) {
|
20
|
+
root.walkRules(rule => {
|
21
|
+
before.forEach((beforeOpt, idx) => {
|
22
|
+
const afterOpt = after[idx];
|
23
|
+
|
24
|
+
if (typeof beforeOpt === 'string') {
|
25
|
+
rule.selector = rule.selector.split(beforeOpt).join(afterOpt);
|
26
|
+
} else {
|
27
|
+
rule.selector = rule.selector.replace(beforeOpt, afterOpt);
|
28
|
+
}
|
29
|
+
});
|
30
|
+
});
|
31
|
+
}
|
32
|
+
|
33
|
+
};
|
34
|
+
};
|
35
|
+
|
36
|
+
exports.default = _default;
|
37
|
+
|
38
|
+
function validator(opts) {
|
39
|
+
if (!opts || typeof opts !== 'object') {
|
40
|
+
throw new Error('Always requires argment');
|
41
|
+
}
|
42
|
+
|
43
|
+
const {
|
44
|
+
before,
|
45
|
+
after
|
46
|
+
} = opts;
|
47
|
+
|
48
|
+
if (!before || !after) {
|
49
|
+
throw new Error('Be sure to have "before" and "after" object names');
|
50
|
+
}
|
51
|
+
|
52
|
+
if (!Array.isArray(before) || !Array.isArray(after)) {
|
53
|
+
throw new Error('Objects "before" and "after" must be of type Array');
|
54
|
+
}
|
55
|
+
|
56
|
+
if (before.length !== after.length) {
|
57
|
+
throw new Error('Length of before and after options must be the same');
|
58
|
+
}
|
59
|
+
|
60
|
+
if (before.length === 0) {
|
61
|
+
throw new Error('Array length is 1 or more');
|
62
|
+
}
|
63
|
+
|
64
|
+
before.forEach((beforeOpt, idx) => {
|
65
|
+
const afterOpt = after[idx];
|
66
|
+
|
67
|
+
switch (true) {
|
68
|
+
case typeof beforeOpt === 'string':
|
69
|
+
{
|
70
|
+
if (!typeof afterOpt === 'string') {
|
71
|
+
throw new Error(`The after option ${afterOpt} must be a string. If you want to apply the replace callback function, then use a RegExp for the before option`);
|
72
|
+
}
|
73
|
+
|
74
|
+
break;
|
75
|
+
}
|
76
|
+
|
77
|
+
case beforeOpt instanceof RegExp:
|
78
|
+
{
|
79
|
+
if (!typeof afterOpt === 'string' && !typeof afterOpt === 'function') {
|
80
|
+
throw new Error(`The after option ${afterOpt} must be either a string, or a function`);
|
81
|
+
}
|
82
|
+
|
83
|
+
break;
|
84
|
+
}
|
85
|
+
|
86
|
+
default:
|
87
|
+
throw new Error(`The before option ${beforeOpt} must be either a string, or a RegExp`);
|
88
|
+
}
|
89
|
+
});
|
90
|
+
}
|
@@ -0,0 +1,57 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.default = void 0;
|
7
|
+
|
8
|
+
const diffBasedOnStrLength = (a, b) => b.length - a.length;
|
9
|
+
/**
|
10
|
+
* @param {Array} valueReplacer
|
11
|
+
* [
|
12
|
+
{
|
13
|
+
"props": ["color", "background-color"],
|
14
|
+
"values" : {
|
15
|
+
"zd-": "im-"
|
16
|
+
}
|
17
|
+
}
|
18
|
+
]
|
19
|
+
*/
|
20
|
+
|
21
|
+
|
22
|
+
const PostcssValueReplacer = (valueReplacer = []) => {
|
23
|
+
const options = {};
|
24
|
+
valueReplacer.forEach(obj => {
|
25
|
+
obj.props.forEach(prop => {
|
26
|
+
const valueKeys = Object.keys(obj.values);
|
27
|
+
const propOptions = options[prop];
|
28
|
+
|
29
|
+
if (options[prop]) {
|
30
|
+
valueKeys.forEach(k => {
|
31
|
+
propOptions.values[k] = obj.values[k];
|
32
|
+
});
|
33
|
+
propOptions.sortedKeys = propOptions.values.sort(diffBasedOnStrLength);
|
34
|
+
} else {
|
35
|
+
options[prop] = {
|
36
|
+
sortedKeys: valueKeys.sort(diffBasedOnStrLength),
|
37
|
+
values: obj.values
|
38
|
+
};
|
39
|
+
}
|
40
|
+
});
|
41
|
+
}); // Work with options here
|
42
|
+
|
43
|
+
return {
|
44
|
+
postcssPlugin: 'postcss-value-replacer',
|
45
|
+
Declaration: decl => {
|
46
|
+
const propOptions = options[decl.prop];
|
47
|
+
propOptions?.sortedKeys.forEach(k => {
|
48
|
+
// eslint-disable-next-line no-param-reassign
|
49
|
+
decl.value = decl.value.replaceAll(k, propOptions.values[k]);
|
50
|
+
});
|
51
|
+
}
|
52
|
+
};
|
53
|
+
};
|
54
|
+
|
55
|
+
PostcssValueReplacer.postcss = true;
|
56
|
+
var _default = PostcssValueReplacer;
|
57
|
+
exports.default = _default;
|
@@ -0,0 +1,347 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.default = void 0;
|
7
|
+
|
8
|
+
var _fs = _interopRequireDefault(require("fs"));
|
9
|
+
|
10
|
+
var _path = _interopRequireDefault(require("path"));
|
11
|
+
|
12
|
+
var _ErrorHandler = require("../../../bundler/webpack/custom_plugins/VariableConversionCollector/ErrorHandler");
|
13
|
+
|
14
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
15
|
+
|
16
|
+
const convertableProps = {
|
17
|
+
'font-size': true,
|
18
|
+
margin: true,
|
19
|
+
'margin-left': true,
|
20
|
+
'margin-right': true,
|
21
|
+
'margin-top': true,
|
22
|
+
'margin-bottom': true,
|
23
|
+
padding: true,
|
24
|
+
'padding-top': true,
|
25
|
+
'padding-bottom': true,
|
26
|
+
'padding-left': true,
|
27
|
+
'padding-right': true,
|
28
|
+
width: true,
|
29
|
+
'min-width': true,
|
30
|
+
'max-width': true,
|
31
|
+
height: true,
|
32
|
+
'min-height': true,
|
33
|
+
'max-height': true,
|
34
|
+
top: true,
|
35
|
+
bottom: true,
|
36
|
+
left: 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
|
45
|
+
};
|
46
|
+
const constantValues = {
|
47
|
+
inherit: true,
|
48
|
+
initial: true,
|
49
|
+
auto: true,
|
50
|
+
'fit-content': 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
|
59
|
+
};
|
60
|
+
|
61
|
+
function getNumericValue(value) {
|
62
|
+
if (value.includes('var')) {
|
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(',', ''));
|
68
|
+
} // Not need for this dum loop
|
69
|
+
// allowed.forEach(alwdUnit => {
|
70
|
+
// if (value.includes(alwdUnit)) {
|
71
|
+
// return parseInt(value);
|
72
|
+
// }
|
73
|
+
// });
|
74
|
+
|
75
|
+
|
76
|
+
if (constantValues[value.toLowerCase()]) {
|
77
|
+
return 1;
|
78
|
+
}
|
79
|
+
|
80
|
+
return parseInt(value);
|
81
|
+
}
|
82
|
+
|
83
|
+
function pxToCalc(value) {
|
84
|
+
const arr = value.split(' ');
|
85
|
+
arr.forEach((val, index) => {
|
86
|
+
['px'].forEach(unit => {
|
87
|
+
const valWithUnit = new RegExp(`(\\d+)${unit}`, 'gi');
|
88
|
+
|
89
|
+
if (valWithUnit.test(val)) {
|
90
|
+
arr[index] = val.replace(valWithUnit, '(var(--zd_size$1))');
|
91
|
+
}
|
92
|
+
});
|
93
|
+
});
|
94
|
+
return arr.join(' ');
|
95
|
+
}
|
96
|
+
|
97
|
+
const singleConvertor = (value, changeVal, details, range) => {
|
98
|
+
const {
|
99
|
+
path,
|
100
|
+
filename,
|
101
|
+
decl
|
102
|
+
} = details;
|
103
|
+
|
104
|
+
if (decl.prop === 'background-position') {
|
105
|
+
if (isNaN(parseInt(value))) {
|
106
|
+
// console.log(`${value} skipped`);
|
107
|
+
return;
|
108
|
+
}
|
109
|
+
}
|
110
|
+
|
111
|
+
if (value == '0px') {
|
112
|
+
value = value.replace('px', '');
|
113
|
+
}
|
114
|
+
|
115
|
+
if (getNumericValue(value) >= range.start && getNumericValue(value) <= range.end || getNumericValue(value) === 0) {
|
116
|
+
let retVal = value.replace(/(\d+)px/gi, changeVal.replace('$$', '$1'));
|
117
|
+
|
118
|
+
if (/^-var/.test(retVal)) {
|
119
|
+
retVal = `calc( ${retVal.substring(1)} * -1 )`;
|
120
|
+
}
|
121
|
+
|
122
|
+
return retVal;
|
123
|
+
} // if (!value.includes('rect')) {
|
124
|
+
// if(unitErrorVal && unitErrorVal != '0' ){
|
125
|
+
// console.log(value, 'not within range')
|
126
|
+
|
127
|
+
|
128
|
+
const errObj = {
|
129
|
+
decl,
|
130
|
+
type: 'RANGE_ERROR',
|
131
|
+
filename,
|
132
|
+
message: `value (${value}) (${typeof value}) not within range (${range.start},${range.end})\r`,
|
133
|
+
path
|
134
|
+
};
|
135
|
+
|
136
|
+
_ErrorHandler.errHandler.errorTable.push(errObj);
|
137
|
+
|
138
|
+
_ErrorHandler.errHandler.errorFunction(errObj); // errorFunction(
|
139
|
+
// {
|
140
|
+
// decl,
|
141
|
+
// type: 'RANGE_ERROR',
|
142
|
+
// filename,
|
143
|
+
// message: `value (${value}) (${typeof value}) not within range (${
|
144
|
+
// range.start
|
145
|
+
// },${range.end})\r`,
|
146
|
+
// path: path
|
147
|
+
// },
|
148
|
+
// 'RANGE_ERROR'
|
149
|
+
// );
|
150
|
+
// }
|
151
|
+
// 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`)
|
152
|
+
// return value;
|
153
|
+
// } else {
|
154
|
+
// console.log('++++++++++++++++++++++rect val!', value);
|
155
|
+
// }
|
156
|
+
|
157
|
+
};
|
158
|
+
|
159
|
+
var _default = ({
|
160
|
+
configFile
|
161
|
+
}) => {
|
162
|
+
const rawdata = _fs.default.readFileSync(configFile);
|
163
|
+
|
164
|
+
const data = JSON.parse(rawdata);
|
165
|
+
const {
|
166
|
+
errorsAllowed,
|
167
|
+
settings: settingsObject // errorLog: errorLogStatus,
|
168
|
+
// errorInConsole: errorConsoleStatus
|
169
|
+
|
170
|
+
} = data; // const keys = Object.keys(settingsObject);
|
171
|
+
|
172
|
+
_ErrorHandler.errHandler.setAllowedErrs(errorsAllowed);
|
173
|
+
|
174
|
+
const replacementArray = [];
|
175
|
+
Object.keys(settingsObject).forEach(key => {
|
176
|
+
Object.values(settingsObject[key].replacements).forEach(val => {
|
177
|
+
if (!replacementArray.includes(val)) {
|
178
|
+
replacementArray.push(val);
|
179
|
+
}
|
180
|
+
});
|
181
|
+
});
|
182
|
+
let regValStr = '';
|
183
|
+
replacementArray.forEach((val, index) => {
|
184
|
+
if (index !== replacementArray.length - 1) {
|
185
|
+
regValStr += `${val.replace('$$', '\\d+').replace('(', '\\(').replace(')', '\\)')}|`;
|
186
|
+
} else {
|
187
|
+
regValStr += `${val.replace('$$', '\\d+').replace('(', '\\(').replace(')', '\\)')}`;
|
188
|
+
}
|
189
|
+
});
|
190
|
+
const valRegex = new RegExp(regValStr, 'gi');
|
191
|
+
return {
|
192
|
+
postcssPlugin: 'postcss-variable-report',
|
193
|
+
Once: rootOriginal => {
|
194
|
+
rootOriginal.walkRules(rule => {
|
195
|
+
// rule.nodes[-1] = {}
|
196
|
+
// need map, forEach fine less memory
|
197
|
+
rule.nodes.forEach((decl, position) => {
|
198
|
+
// case font-size
|
199
|
+
const commentStr = 'variable:ignore';
|
200
|
+
const prevNode = rule.nodes[position - 1];
|
201
|
+
const fromPath = rootOriginal.source.input.from; // this will be problem for linux and mac use require('path').sep
|
202
|
+
// split not need use slice and lastIndexOf less memory
|
203
|
+
|
204
|
+
const filename = fromPath.split(_path.default.sep).pop(); // if(filename.includes('AddFormResponsive.module.css'){
|
205
|
+
// }
|
206
|
+
|
207
|
+
if (prevNode && prevNode.type === 'comment' && prevNode.text.toLowerCase().includes(commentStr)) {
|
208
|
+
const errObj = {
|
209
|
+
decl,
|
210
|
+
type: 'DECLARATION_IGNORED',
|
211
|
+
filename,
|
212
|
+
message: 'Declaration Ignored',
|
213
|
+
path: fromPath
|
214
|
+
};
|
215
|
+
|
216
|
+
_ErrorHandler.errHandler.errorTable.push(errObj);
|
217
|
+
|
218
|
+
_ErrorHandler.errHandler.DECLARATION_IGNORED(errObj);
|
219
|
+
|
220
|
+
return;
|
221
|
+
}
|
222
|
+
|
223
|
+
if (settingsObject[decl.prop] && !decl.value.includes('var(--')) {
|
224
|
+
const settings = settingsObject[decl.prop]; // console.log(settings)
|
225
|
+
|
226
|
+
const {
|
227
|
+
allowed,
|
228
|
+
range
|
229
|
+
} = settings; // suggestion filter !decl.value.includes('calc')
|
230
|
+
// Reason below some of logic happen based on this
|
231
|
+
|
232
|
+
const unit = decl.value.toString() // no need round braket since you do not need group for less memory
|
233
|
+
.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('-',''))
|
234
|
+
// console.log('unit : ');
|
235
|
+
// console.log(unit);
|
236
|
+
|
237
|
+
unit.forEach((val, index) => {
|
238
|
+
allowed.forEach(alwdVal => {
|
239
|
+
if (val.includes(alwdVal)) {
|
240
|
+
// ## for what purpose
|
241
|
+
unit[index] = val // .replace(new RegExp('(\\d+).(\\d+)(\\w+)', 'gi'), '$3')
|
242
|
+
.replace(`-${alwdVal}`, `${alwdVal}`).replace(`-.${alwdVal}`, `${alwdVal}`).replace(`${alwdVal},`, `${alwdVal}`);
|
243
|
+
}
|
244
|
+
});
|
245
|
+
});
|
246
|
+
let unitError = false;
|
247
|
+
let unitErrorVal = '';
|
248
|
+
unit.forEach(val => {
|
249
|
+
if (!val.includes('calc') && decl.prop !== 'clip') {
|
250
|
+
if (!allowed.includes(val.toString())) {
|
251
|
+
unitError = true;
|
252
|
+
unitErrorVal = val;
|
253
|
+
}
|
254
|
+
}
|
255
|
+
}); // console.log(allowed, replacements, range)
|
256
|
+
|
257
|
+
if (!unitError) {
|
258
|
+
// use variable decl.value.split(' ')
|
259
|
+
if (range) {
|
260
|
+
// console.log('multiple :', decl.value)
|
261
|
+
let newVal = '';
|
262
|
+
decl.value.split(' ').forEach(singleVal => {
|
263
|
+
newVal += `${singleConvertor(singleVal, settings.replacements.px, {
|
264
|
+
decl,
|
265
|
+
filename,
|
266
|
+
path: fromPath
|
267
|
+
}, range)} `;
|
268
|
+
});
|
269
|
+
decl.value = newVal;
|
270
|
+
}
|
271
|
+
} else if (!decl.value.includes('calc')) {
|
272
|
+
// 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`);
|
273
|
+
const errObj = {
|
274
|
+
decl,
|
275
|
+
filename,
|
276
|
+
unitErrorVal,
|
277
|
+
path: fromPath
|
278
|
+
};
|
279
|
+
|
280
|
+
if (unitErrorVal.trim() === '.') {
|
281
|
+
errObj.type = 'DECIMAL_CHECK';
|
282
|
+
errObj.message = `${unitErrorVal} (Decimal Value) Please check`;
|
283
|
+
|
284
|
+
_ErrorHandler.errHandler.errorTable.push(errObj);
|
285
|
+
|
286
|
+
_ErrorHandler.errHandler.DECIMAL_CHECK(errObj);
|
287
|
+
} else if (unitErrorVal.includes('.') && !unitErrorVal.includes('%')) {
|
288
|
+
errObj.type = 'DECIMAL_REJECT';
|
289
|
+
errObj.message = `${unitErrorVal} (Decimal Value) Not Allowed \r`;
|
290
|
+
|
291
|
+
_ErrorHandler.errHandler.errorTable.push(errObj);
|
292
|
+
|
293
|
+
_ErrorHandler.errHandler.DECIMAL_REJECT(errObj);
|
294
|
+
} else if (!unitErrorVal.includes('%')) {
|
295
|
+
errObj.type = 'UNIT_ERROR';
|
296
|
+
errObj.message = `${unitErrorVal} (Unit) Not Allowed`;
|
297
|
+
|
298
|
+
_ErrorHandler.errHandler.errorTable.push(errObj);
|
299
|
+
|
300
|
+
_ErrorHandler.errHandler.UNIT_ERROR(errObj);
|
301
|
+
}
|
302
|
+
} else {
|
303
|
+
decl.value = pxToCalc(decl.value);
|
304
|
+
}
|
305
|
+
} else {
|
306
|
+
if (settingsObject[decl.prop] && decl.value && decl.value.includes('px') && decl.value.includes('var(--')) {
|
307
|
+
const valArr = decl.value.split(' ');
|
308
|
+
const settings = settingsObject[decl.prop];
|
309
|
+
const {
|
310
|
+
range
|
311
|
+
} = settings;
|
312
|
+
const convertedVals = valArr.map(val => {
|
313
|
+
if (val.includes('px')) {
|
314
|
+
const convertedVal = singleConvertor(val, settings.replacements.px, {
|
315
|
+
decl,
|
316
|
+
filename,
|
317
|
+
path: fromPath
|
318
|
+
}, range);
|
319
|
+
return convertedVal || val;
|
320
|
+
}
|
321
|
+
|
322
|
+
return val;
|
323
|
+
});
|
324
|
+
decl.value = convertedVals.join(' ');
|
325
|
+
}
|
326
|
+
|
327
|
+
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')) {
|
328
|
+
const errObj = {
|
329
|
+
decl,
|
330
|
+
type: 'VARIABLE_PRESENT',
|
331
|
+
filename,
|
332
|
+
message: `value (${decl.value}) has var in it, kindly check`,
|
333
|
+
path: fromPath
|
334
|
+
};
|
335
|
+
|
336
|
+
_ErrorHandler.errHandler.errorTable.push(errObj);
|
337
|
+
|
338
|
+
_ErrorHandler.errHandler.VARIABLE_PRESENT(errObj);
|
339
|
+
}
|
340
|
+
}
|
341
|
+
});
|
342
|
+
});
|
343
|
+
}
|
344
|
+
};
|
345
|
+
};
|
346
|
+
|
347
|
+
exports.default = _default;
|
@@ -0,0 +1,55 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.filterCustomPluginsAllowedForSpecificFile = filterCustomPluginsAllowedForSpecificFile;
|
7
|
+
exports.filterPluginsAllowedForSpecificFile = filterPluginsAllowedForSpecificFile;
|
8
|
+
exports.getEnabledPlugins = getEnabledPlugins;
|
9
|
+
exports.mapDefaultSupportedPlugins = mapDefaultSupportedPlugins;
|
10
|
+
|
11
|
+
var _checkIsPatternsMatchFilename = require("../bundler/webpack/loaderConfigs/checkIsPatternsMatchFilename");
|
12
|
+
|
13
|
+
var _getSpecificPostCssPlugin = require("./getSpecificPostCssPlugin");
|
14
|
+
|
15
|
+
/* eslint-disable no-use-before-define */
|
16
|
+
function mapDefaultSupportedPlugins(pluginsOptions) {
|
17
|
+
return _getSpecificPostCssPlugin.supportedPluginsOptionNames.map(pluginName => ({ ...pluginsOptions[pluginName],
|
18
|
+
pluginName
|
19
|
+
}));
|
20
|
+
}
|
21
|
+
|
22
|
+
function getEnabledPlugins(pluginsOptions) {
|
23
|
+
function isEnabled(pluginName) {
|
24
|
+
return pluginsOptions[pluginName].enable;
|
25
|
+
}
|
26
|
+
|
27
|
+
return _getSpecificPostCssPlugin.supportedPluginsOptionNames.filter(isEnabled).map(pluginName => ({ ...pluginsOptions[pluginName],
|
28
|
+
pluginName
|
29
|
+
}));
|
30
|
+
}
|
31
|
+
|
32
|
+
function filterPluginsAllowedForSpecificFile(plugins, filename) {
|
33
|
+
return plugins.filter(pluginOption => checkIsPluginAllowed(pluginOption, filename)).map(pluginOption => (0, _getSpecificPostCssPlugin.getSpecificPostCssPlugin)(pluginOption)).filter(Boolean);
|
34
|
+
}
|
35
|
+
|
36
|
+
function checkIsPluginAllowed(pluginOption, filename) {
|
37
|
+
return (0, _checkIsPatternsMatchFilename.checkIsPatternsMatchFilename)(pluginOption.patterns, filename);
|
38
|
+
}
|
39
|
+
|
40
|
+
function getCustomPlugins(pluginOption) {
|
41
|
+
if (typeof pluginOption.plugin === 'string') {
|
42
|
+
// eslint-disable-next-line import/no-dynamic-require, global-require
|
43
|
+
return require(pluginOption.plugin).plugin(pluginOption);
|
44
|
+
}
|
45
|
+
|
46
|
+
if (typeof pluginOption.plugin === 'function') {
|
47
|
+
return pluginOption.plugin(pluginOption);
|
48
|
+
}
|
49
|
+
|
50
|
+
return null;
|
51
|
+
}
|
52
|
+
|
53
|
+
function filterCustomPluginsAllowedForSpecificFile(customPlugins, filename) {
|
54
|
+
return customPlugins.filter(pluginOption => checkIsPluginAllowed(pluginOption, filename)).map(getCustomPlugins).filter(Boolean);
|
55
|
+
}
|