@ui5/webcomponents-tools 0.0.0-a7032d86e → 0.0.0-a8a75c830
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/CHANGELOG.md +2188 -0
- package/LICENSE.txt +201 -0
- package/README.md +7 -9
- package/assets-meta.js +12 -11
- package/bin/dev.js +10 -4
- package/bin/ui5nps.js +301 -0
- package/components-package/eslint.js +51 -15
- package/components-package/nps.js +123 -80
- package/components-package/postcss.components.js +1 -21
- package/components-package/postcss.themes.js +1 -26
- package/components-package/vite.config.js +7 -10
- package/components-package/wdio.js +43 -15
- package/icons-collection/nps.js +32 -19
- package/lib/amd-to-es6/index.js +109 -0
- package/lib/amd-to-es6/no-remaining-require.js +33 -0
- package/lib/cem/cem.js +16 -0
- package/lib/cem/custom-elements-manifest.config.mjs +575 -0
- package/lib/cem/event.mjs +168 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/cli.js +128 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/package.json +59 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/browser-entrypoint.js +23 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/create.js +117 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/arrow-function.js +26 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/class-jsdoc.js +157 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/classes.js +20 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/creators/createArrowFunction.js +17 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/creators/createAttribute.js +24 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/creators/createClass.js +301 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/creators/createClassField.js +26 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/creators/createFunctionLike.js +73 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/creators/createMixin.js +33 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/creators/createVariable.js +22 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/creators/handlers.js +338 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/custom-elements-define-calls.js +90 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/exports.js +156 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/function-like.js +24 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/mixins.js +29 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/reexported-wrapped-mixin-exports.js +84 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/analyse-phase/variables.js +34 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/collect-phase/collect-imports.js +101 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/catalyst/catalyst.js +11 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/catalyst/controller.js +34 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/catalyst-major-2/catalyst.js +11 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/catalyst-major-2/controller.js +34 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/decorators/attr.js +53 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/decorators/custom-element-decorator.js +36 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/fast/fast.js +7 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/lit/lit.js +13 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/lit/member-denylist.js +21 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/lit/method-denylist.js +20 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/lit/property-decorator.js +94 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/lit/static-properties.js +121 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/lit/utils.js +66 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/framework-plugins/stencil/stencil.js +129 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/index.js +80 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/link-phase/cleanup-classes.js +25 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/link-phase/field-denylist.js +22 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/link-phase/method-denylist.js +25 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/post-processing/apply-inheritance.js +78 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/post-processing/is-custom-element.js +34 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/post-processing/link-class-to-tagname.js +27 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/post-processing/remove-unexported-declarations.js +23 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/features/post-processing/resolve-initializers.js +52 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/utils/ast-helpers.js +186 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/utils/cli-helpers.js +164 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/utils/exports.js +44 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/utils/find-external-manifests.js +67 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/utils/imports.js +25 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/utils/index.js +71 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/utils/jsdoc.js +19 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/utils/manifest-helpers.js +194 -0
- package/lib/cem/patch/@custom-elements-manifest/analyzer/src/utils/mixins.js +112 -0
- package/lib/cem/schema-internal.json +1422 -0
- package/lib/cem/schema.json +1098 -0
- package/lib/cem/types-internal.d.ts +808 -0
- package/lib/cem/types.d.ts +736 -0
- package/lib/cem/utils.mjs +429 -0
- package/lib/cem/validate.js +81 -0
- package/lib/chokidar/chokidar.js +28 -0
- package/lib/copy-and-watch/index.js +110 -97
- package/lib/copy-list/index.js +18 -10
- package/lib/create-icons/index.js +57 -27
- package/lib/create-illustrations/index.js +94 -45
- package/lib/create-new-component/Component.js +74 -0
- package/lib/create-new-component/ComponentTemplate.js +12 -0
- package/lib/create-new-component/index.js +62 -101
- package/lib/css-processors/css-processor-components.mjs +103 -0
- package/lib/css-processors/css-processor-themes.mjs +122 -0
- package/lib/css-processors/postcss-plugin.mjs +153 -0
- package/lib/css-processors/scope-variables.mjs +74 -0
- package/lib/css-processors/shared.mjs +47 -0
- package/lib/dev-server/custom-hot-update-plugin.js +39 -0
- package/lib/dev-server/{dev-server.js → dev-server.mjs} +26 -14
- package/lib/dev-server/virtual-index-html-plugin.js +24 -21
- package/lib/eslint/eslint.js +44 -0
- package/lib/generate-js-imports/illustrations.js +79 -64
- package/lib/generate-json-imports/i18n.js +63 -68
- package/lib/generate-json-imports/themes.js +38 -43
- package/lib/hbs2lit/src/compiler.js +9 -6
- package/lib/hbs2lit/src/litVisitor2.js +42 -17
- package/lib/hbs2lit/src/svgProcessor.js +12 -5
- package/lib/hbs2ui5/RenderTemplates/LitRenderer.js +39 -6
- package/lib/hbs2ui5/index.js +23 -6
- package/lib/i18n/defaults.js +24 -9
- package/lib/i18n/toJSON.js +41 -13
- package/lib/icons-hash/icons-hash.mjs +149 -0
- package/lib/postcss-combine-duplicated-selectors/index.js +12 -5
- package/lib/remove-dev-mode/remove-dev-mode.mjs +51 -0
- package/lib/rimraf/rimraf.js +31 -0
- package/lib/scoping/get-all-tags.js +10 -3
- package/lib/scoping/lint-src.js +8 -7
- package/lib/scoping/scope-test-pages.js +2 -1
- package/lib/test-runner/test-runner.js +59 -43
- package/lib/vite-bundler/vite-bundler.mjs +35 -0
- package/package.json +36 -25
- package/tsconfig.json +18 -0
- package/components-package/wdio.sync.js +0 -360
- package/lib/esm-abs-to-rel/index.js +0 -58
- package/lib/generate-custom-elements-manifest/index.js +0 -373
- package/lib/jsdoc/config.json +0 -29
- package/lib/jsdoc/configTypescript.json +0 -29
- package/lib/jsdoc/plugin.js +0 -2468
- package/lib/jsdoc/preprocess.js +0 -146
- package/lib/jsdoc/template/publish.js +0 -4120
- package/lib/postcss-css-to-esm/index.js +0 -57
- package/lib/postcss-css-to-json/index.js +0 -47
- package/lib/postcss-new-files/index.js +0 -36
- package/lib/postcss-p/postcss-p.mjs +0 -14
- package/lib/replace-global-core/index.js +0 -25
|
@@ -1,11 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
const fs = require("fs");
|
|
2
|
+
const path = require("path");
|
|
3
|
+
const tsMode = fs.existsSync(path.join(process.cwd(), "tsconfig.json"));
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Returns eslint rules specific to typescript files
|
|
7
|
+
* @returns
|
|
8
|
+
*/
|
|
9
|
+
const getTsModeOverrides = () => {
|
|
10
|
+
const tsConfiguration = {
|
|
9
11
|
files: ["*.ts"],
|
|
10
12
|
parser: "@typescript-eslint/parser",
|
|
11
13
|
plugins: ["@typescript-eslint"],
|
|
@@ -14,13 +16,15 @@ module.exports = {
|
|
|
14
16
|
"plugin:@typescript-eslint/recommended-requiring-type-checking"
|
|
15
17
|
],
|
|
16
18
|
parserOptions: {
|
|
17
|
-
|
|
19
|
+
"project": [
|
|
20
|
+
"./tsconfig.json"
|
|
21
|
+
],
|
|
22
|
+
EXPERIMENTAL_useSourceOfProjectReferenceRedirect: true,
|
|
18
23
|
},
|
|
19
|
-
/**
|
|
20
|
-
* Typescript Rules
|
|
21
|
-
*/
|
|
22
24
|
rules: {
|
|
23
25
|
"no-shadow": "off",
|
|
26
|
+
"@typescript-eslint/consistent-type-imports": "error",
|
|
27
|
+
"import/consistent-type-specifier-style": ["error", "prefer-top-level"],
|
|
24
28
|
"@typescript-eslint/no-shadow": ["error"],
|
|
25
29
|
"@typescript-eslint/no-unsafe-member-access": "off",
|
|
26
30
|
"@typescript-eslint/no-floating-promises": "off",
|
|
@@ -30,9 +34,40 @@ module.exports = {
|
|
|
30
34
|
"@typescript-eslint/no-unsafe-call": "off",
|
|
31
35
|
"@typescript-eslint/no-non-null-assertion": "off",
|
|
32
36
|
"@typescript-eslint/no-empty-function": "off",
|
|
37
|
+
"@typescript-eslint/no-empty-interface": "off",
|
|
33
38
|
"lines-between-class-members": "off",
|
|
34
39
|
}
|
|
35
|
-
}
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
const tsxConfiguration = JSON.parse(JSON.stringify(tsConfiguration));
|
|
43
|
+
tsxConfiguration.files = ["*.tsx"];
|
|
44
|
+
tsxConfiguration.plugins.push("jsx-no-leaked-values");
|
|
45
|
+
tsxConfiguration.rules = {
|
|
46
|
+
...tsxConfiguration.rules,
|
|
47
|
+
"jsx-no-leaked-values/jsx-no-leaked-values": "error",
|
|
48
|
+
"@typescript-eslint/unbound-method": "off", // to be able to attach on* listeners
|
|
49
|
+
"@typescript-eslint/no-misused-promises": "off", // to be able to have async event listeners
|
|
50
|
+
"operator-linebreak": "off",
|
|
51
|
+
"no-nested-ternary": "off",
|
|
52
|
+
"implicit-arrow-linebreak": "off",
|
|
53
|
+
"function-paren-newline": "off",
|
|
54
|
+
"comma-dangle": "off"
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
return [
|
|
58
|
+
tsConfiguration,
|
|
59
|
+
tsxConfiguration
|
|
60
|
+
];
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
module.exports = {
|
|
64
|
+
"env": {
|
|
65
|
+
"browser": true,
|
|
66
|
+
"es6": true
|
|
67
|
+
},
|
|
68
|
+
"root": true,
|
|
69
|
+
"extends": "airbnb-base",
|
|
70
|
+
"overrides": tsMode ? getTsModeOverrides() : [],
|
|
36
71
|
"parserOptions": {
|
|
37
72
|
"ecmaVersion": 2018,
|
|
38
73
|
"sourceType": "module"
|
|
@@ -75,6 +110,7 @@ module.exports = {
|
|
|
75
110
|
"curly": [2, "all"],
|
|
76
111
|
// "default-case": 1, // removed for UI5 WebComponents
|
|
77
112
|
"import/extensions": ["error", "always"], // override for UI5 WebComponents
|
|
113
|
+
"import/order": "off",
|
|
78
114
|
"no-alert": 2,
|
|
79
115
|
"no-caller": 2,
|
|
80
116
|
"no-div-regex": 2,
|
|
@@ -116,7 +152,7 @@ module.exports = {
|
|
|
116
152
|
"no-shadow-restricted-names": 2,
|
|
117
153
|
"no-undef-init": 2,
|
|
118
154
|
"no-undef": 2,
|
|
119
|
-
"no-unused-vars": [2, {"vars":"all", "args":"none"}],
|
|
155
|
+
"no-unused-vars": [2, { "vars": "all", "args": "none" }],
|
|
120
156
|
|
|
121
157
|
"brace-style": [2, "1tbs", { "allowSingleLine": true }],
|
|
122
158
|
"camelcase": [1, { "properties": "never" }], // added for UI5 WebComponents
|
|
@@ -132,7 +168,7 @@ module.exports = {
|
|
|
132
168
|
"no-new-object": 2,
|
|
133
169
|
"no-spaced-func": 2,
|
|
134
170
|
"quote-props": [2, "as-needed", { "keywords": true, "unnecessary": false }],
|
|
135
|
-
"semi-spacing": [1, {"before": false, "after": true}],
|
|
171
|
+
"semi-spacing": [1, { "before": false, "after": true }],
|
|
136
172
|
"semi": 2,
|
|
137
173
|
"keyword-spacing": 2,
|
|
138
174
|
"space-infix-ops": 2,
|
|
@@ -1,21 +1,58 @@
|
|
|
1
1
|
const path = require("path");
|
|
2
2
|
const fs = require("fs");
|
|
3
|
-
const resolve = require("resolve");
|
|
4
3
|
const LIB = path.join(__dirname, `../lib/`);
|
|
5
|
-
|
|
4
|
+
let websiteBaseUrl = "/";
|
|
6
5
|
|
|
7
|
-
const
|
|
6
|
+
const isPreview = !!process.env.PR_NUMBER;
|
|
7
|
+
const getPreviewBaseUrl = () => {
|
|
8
|
+
if (process.env.DEPLOYMENT_TYPE === "netlify_preview") {
|
|
9
|
+
return "/";
|
|
10
|
+
}
|
|
11
|
+
return `/webcomponents/pr-${process.env.PR_NUMBER}/`;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
if (process.env.DEPLOY) {
|
|
15
|
+
websiteBaseUrl = "/webcomponents/";
|
|
16
|
+
} else if (process.env.DEPLOY_NIGHTLY) {
|
|
17
|
+
websiteBaseUrl = "/webcomponents/nightly/";
|
|
18
|
+
} else if (isPreview) {
|
|
19
|
+
websiteBaseUrl = getPreviewBaseUrl();
|
|
20
|
+
}
|
|
8
21
|
|
|
22
|
+
const getScripts = (options) => {
|
|
9
23
|
// The script creates all JS modules (dist/illustrations/{illustrationName}.js) out of the existing SVGs
|
|
10
24
|
const illustrationsData = options.illustrationsData || [];
|
|
11
|
-
|
|
12
|
-
|
|
25
|
+
const createIllustrationsJSImportsScript = {
|
|
26
|
+
default: `ui5nps-p ${illustrationsData.map(illustrations => `build.illustrations.build-${illustrations.set}-${illustrations.collection}`).join(" ")}` // concurently,
|
|
27
|
+
}
|
|
28
|
+
illustrationsData.forEach((illustration) => {
|
|
29
|
+
createIllustrationsJSImportsScript[`build-${illustration.set}-${illustration.collection}`] = `ui5nps-script "${LIB}create-illustrations/index.js" ${illustration.path} ${illustration.defaultText} ${illustration.illustrationsPrefix} ${illustration.set} ${illustration.destinationPath} ${illustration.collection}`
|
|
30
|
+
});
|
|
31
|
+
// The script creates the "src/generated/js-imports/Illustration.js" file that registers loaders (dynamic JS imports) for each illustration
|
|
32
|
+
const createIllustrationsLoadersScript = {
|
|
33
|
+
default: `ui5nps-p ${illustrationsData.map(illustrations => `build.jsImports.illustrationsLoaders.generate-${illustrations.set}-${illustrations.collection}`).join(" ")}` // concurently,
|
|
34
|
+
}
|
|
35
|
+
illustrationsData.forEach((illustrations) => {
|
|
36
|
+
createIllustrationsLoadersScript[`generate-${illustrations.set}-${illustrations.collection}`] = `ui5nps-script ${LIB}generate-js-imports/illustrations.js ${illustrations.path} ${illustrations.dynamicImports.outputFile} ${illustrations.set} ${illustrations.collection} ${illustrations.dynamicImports.location} ${illustrations.dynamicImports.filterOut.join(",")}`
|
|
37
|
+
});
|
|
38
|
+
|
|
13
39
|
|
|
14
|
-
|
|
15
|
-
const
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
40
|
+
const tsOption = !!(!options.legacy || options.jsx);
|
|
41
|
+
const tsCommandOld = tsOption ? "tsc" : "";
|
|
42
|
+
let tsWatchCommandStandalone = tsOption ? "tsc --watch" : "";
|
|
43
|
+
// this command is only used for standalone projects. monorepo projects get their watch from vite, so opt-out here
|
|
44
|
+
if (options.noWatchTS) {
|
|
45
|
+
tsWatchCommandStandalone = "";
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
if (tsOption) {
|
|
49
|
+
try {
|
|
50
|
+
require("typescript");
|
|
51
|
+
} catch (e) {
|
|
52
|
+
console.error(`TypeScript is not found. Try to install it by running \`npm install --save-dev typescript\` if you are using npm or by running \`yarn add --dev typescript\` if you are using yarn.`);
|
|
53
|
+
process.exit(e.code);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
19
56
|
|
|
20
57
|
let viteConfig;
|
|
21
58
|
if (fs.existsSync("config/vite.config.js")) {
|
|
@@ -29,102 +66,108 @@ const getScripts = (options) => {
|
|
|
29
66
|
viteConfig = `-c "${require.resolve("@ui5/webcomponents-tools/components-package/vite.config.js")}"`;
|
|
30
67
|
}
|
|
31
68
|
|
|
32
|
-
let eslintConfig;
|
|
33
|
-
if (fs.existsSync("config/.eslintrc.js")) {
|
|
34
|
-
// old project setup where config file is in separate folder
|
|
35
|
-
eslintConfig = "--config config/.eslintrc.js";
|
|
36
|
-
} else if (fs.existsSync(".eslintrc.js")) {
|
|
37
|
-
// preferred way of custom configuration in root project folder
|
|
38
|
-
eslintConfig = "";
|
|
39
|
-
} else {
|
|
40
|
-
// no custom configuration - use default from tools project
|
|
41
|
-
eslintConfig = `--config "${require.resolve("@ui5/webcomponents-tools/components-package/eslint.js")}"`;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
69
|
const scripts = {
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
70
|
+
__ui5envs: {
|
|
71
|
+
UI5_CEM_MODE: options.dev,
|
|
72
|
+
UI5_TS: `${tsOption}`,
|
|
73
|
+
CSS_VARIABLES_TARGET: options.cssVariablesTarget ?? "root",
|
|
74
|
+
CYPRESS_COVERAGE: !!(options.internal?.cypress_code_coverage),
|
|
75
|
+
},
|
|
76
|
+
clean: {
|
|
77
|
+
"default": "ui5nps clean.generated clean.dist scope.testPages.clean",
|
|
78
|
+
"generated": `ui5nps-script "${LIB}/rimraf/rimraf.js src/generated`,
|
|
79
|
+
"dist": `ui5nps-script "${LIB}/rimraf/rimraf.js dist`,
|
|
80
|
+
},
|
|
81
|
+
lint: `ui5nps-script "${LIB}eslint/eslint.js"`,
|
|
82
|
+
lintfix: `ui5nps-script "${LIB}eslint/eslint.js" --fix`,
|
|
83
|
+
generate: {
|
|
84
|
+
default: `ui5nps prepare.all`,
|
|
85
|
+
all: `ui5nps-p build.templates build.i18n prepare.styleRelated copyProps build.illustrations`, // concurently
|
|
86
|
+
styleRelated: "ui5nps build.styles build.jsonImports build.jsImports",
|
|
87
|
+
},
|
|
48
88
|
prepare: {
|
|
49
|
-
default:
|
|
50
|
-
all:
|
|
51
|
-
styleRelated: "
|
|
89
|
+
default: `ui5nps clean prepare.all copy copyProps prepare.typescript generateAPI`,
|
|
90
|
+
all: `ui5nps-p build.templates build.i18n prepare.styleRelated build.illustrations`, // concurently
|
|
91
|
+
styleRelated: "ui5nps build.styles build.jsonImports build.jsImports",
|
|
92
|
+
typescript: tsCommandOld,
|
|
52
93
|
},
|
|
53
|
-
typescript: tsCommand,
|
|
54
94
|
build: {
|
|
55
|
-
default: "
|
|
56
|
-
templates:
|
|
95
|
+
default: "ui5nps prepare lint build.bundle", // build.bundle2
|
|
96
|
+
templates: options.legacy ? `node "${LIB}hbs2ui5/index.js" -d src/ -o src/generated/templates` : "",
|
|
57
97
|
styles: {
|
|
58
|
-
default:
|
|
59
|
-
themes: `
|
|
60
|
-
|
|
98
|
+
default: `ui5nps-p build.styles.themes build.styles.components`, // concurently
|
|
99
|
+
themes: `ui5nps-script "${LIB}css-processors/css-processor-themes.mjs"`,
|
|
100
|
+
themesWithWatch: `ui5nps-script "${LIB}css-processors/css-processor-themes.mjs" -w`,
|
|
101
|
+
components: `ui5nps-script "${LIB}css-processors/css-processor-components.mjs"`,
|
|
102
|
+
componentsWithWatch: `ui5nps-script "${LIB}css-processors/css-processor-components.mjs" -w`,
|
|
61
103
|
},
|
|
62
104
|
i18n: {
|
|
63
|
-
default: "
|
|
64
|
-
defaultsjs: `
|
|
65
|
-
json: `
|
|
105
|
+
default: "ui5nps build.i18n.defaultsjs build.i18n.json",
|
|
106
|
+
defaultsjs: `ui5nps-script "${LIB}i18n/defaults.js" src/i18n src/generated/i18n`,
|
|
107
|
+
json: `ui5nps-script "${LIB}i18n/toJSON.js" src/i18n dist/generated/assets/i18n`,
|
|
66
108
|
},
|
|
67
109
|
jsonImports: {
|
|
68
|
-
default: "
|
|
69
|
-
themes: `
|
|
70
|
-
i18n: `
|
|
110
|
+
default: "ui5nps build.jsonImports.themes build.jsonImports.i18n",
|
|
111
|
+
themes: `ui5nps-script "${LIB}generate-json-imports/themes.js" src/themes src/generated/json-imports`,
|
|
112
|
+
i18n: `ui5nps-script "${LIB}generate-json-imports/i18n.js" src/i18n src/generated/json-imports`,
|
|
71
113
|
},
|
|
72
114
|
jsImports: {
|
|
73
|
-
default: "
|
|
115
|
+
default: "ui5nps build.jsImports.illustrationsLoaders",
|
|
74
116
|
illustrationsLoaders: createIllustrationsLoadersScript,
|
|
75
117
|
},
|
|
76
|
-
bundle: `vite
|
|
118
|
+
bundle: `ui5nps-script "${LIB}vite-bundler/vite-bundler.mjs" ${viteConfig} --mode testing --base ${websiteBaseUrl}`,
|
|
119
|
+
bundle2: ``,
|
|
77
120
|
illustrations: createIllustrationsJSImportsScript,
|
|
78
121
|
},
|
|
122
|
+
copyProps: `ui5nps-script "${LIB}copy-and-watch/index.js" --silent "src/i18n/*.properties" dist/`,
|
|
123
|
+
copyPropsWithWatch: `ui5nps-script "${LIB}copy-and-watch/index.js" --silent "src/i18n/*.properties" dist/ --watch --safe --skip-initial-copy`,
|
|
124
|
+
copySrcWithWatch: `ui5nps-script "${LIB}copy-and-watch/index.js" --silent "src/**/*.{js,json}" dist/ --watch --safe --skip-initial-copy`,
|
|
79
125
|
copy: {
|
|
80
|
-
default: "
|
|
81
|
-
src: `
|
|
82
|
-
props: `
|
|
126
|
+
default: options.legacy ? "ui5nps copy.src copy.props" : "",
|
|
127
|
+
src: options.legacy ? `ui5nps-script "${LIB}copy-and-watch/index.js" --silent "src/**/*.{js,json}" dist/` : "",
|
|
128
|
+
props: options.legacy ? `ui5nps-script "${LIB}copy-and-watch/index.js" --silent "src/i18n/*.properties" dist/` : "",
|
|
83
129
|
},
|
|
84
130
|
watch: {
|
|
85
|
-
default:
|
|
86
|
-
devServer: '
|
|
87
|
-
src: '
|
|
88
|
-
typescript:
|
|
89
|
-
props: '
|
|
90
|
-
bundle: `
|
|
131
|
+
default: `ui5nps-p watch.templates watch.typescript watch.src watch.styles watch.i18n watch.props`, // concurently
|
|
132
|
+
devServer: 'ui5nps-p watch.default watch.bundle', // concurently
|
|
133
|
+
src: options.legacy ? 'ui5nps copySrcWithWatch' : "",
|
|
134
|
+
typescript: tsWatchCommandStandalone,
|
|
135
|
+
props: 'ui5nps copyPropsWithWatch',
|
|
136
|
+
bundle: `ui5nps-script ${LIB}dev-server/dev-server.mjs ${viteConfig}`,
|
|
91
137
|
styles: {
|
|
92
|
-
default: '
|
|
93
|
-
themes: '
|
|
94
|
-
components:
|
|
95
|
-
default: 'concurrently "nps watch.styles.components.existingFiles" "nps watch.styles.components.newFiles"',
|
|
96
|
-
existingFiles: `nps "build.styles.components -w"`,
|
|
97
|
-
newFiles: `node "${LIB}/postcss-new-files/index.js" --srcFiles="src/themes/*.css"`,
|
|
98
|
-
},
|
|
138
|
+
default: 'ui5nps-p watch.styles.themes watch.styles.components', // concurently
|
|
139
|
+
themes: 'ui5nps build.styles.themesWithWatch',
|
|
140
|
+
components: `ui5nps build.styles.componentsWithWatch`,
|
|
99
141
|
},
|
|
100
|
-
templates:
|
|
101
|
-
|
|
102
|
-
i18n: 'chokidar "src/i18n/messagebundle.properties" -c "nps build.i18n.defaultsjs"'
|
|
142
|
+
templates: options.legacy ? `ui5nps-script "${LIB}chokidar/chokidar.js" "src/**/*.hbs" "ui5nps build.templates"` : "",
|
|
143
|
+
i18n: `ui5nps-script "${LIB}chokidar/chokidar.js" "src/i18n/messagebundle.properties" "ui5nps build.i18n.defaultsjs"`
|
|
103
144
|
},
|
|
104
|
-
start: "
|
|
105
|
-
test: `
|
|
106
|
-
"test-
|
|
107
|
-
"test-suite-
|
|
108
|
-
|
|
145
|
+
start: "ui5nps prepare watch.devServer",
|
|
146
|
+
test: `ui5nps-script "${LIB}/test-runner/test-runner.js"`,
|
|
147
|
+
"test-cy-ci": `cypress run --component --browser chrome`,
|
|
148
|
+
"test-cy-ci-suite-1": `cypress run --component --browser chrome --spec "**/specs/[A-C]*.cy.{js,jsx,ts,tsx},**/specs/[^D-Z]*.cy.{js,jsx,ts,tsx}"`,
|
|
149
|
+
"test-cy-ci-suite-2": `cypress run --component --browser chrome --spec "**/specs/[D-L]*.cy.{js,jsx,ts,tsx}"`,
|
|
150
|
+
"test-cy-ci-suite-3": `cypress run --component --browser chrome --spec "**/specs/[M-S]*.cy.{js,jsx,ts,tsx}"`,
|
|
151
|
+
"test-cy-ci-suite-4": `cypress run --component --browser chrome --spec "**/specs/[T-Z]*.cy.{js,jsx,ts,tsx}"`,
|
|
152
|
+
"test-cy-open": `cypress open --component --browser chrome`,
|
|
153
|
+
startWithScope: "ui5nps scope.prepare scope.watchWithBundle",
|
|
109
154
|
scope: {
|
|
110
|
-
prepare: "
|
|
111
|
-
lint: `
|
|
155
|
+
prepare: "ui5nps scope.lint scope.testPages",
|
|
156
|
+
lint: `ui5nps-script "${LIB}scoping/lint-src.js"`,
|
|
112
157
|
testPages: {
|
|
113
|
-
default: "
|
|
114
|
-
clean: "rimraf test/pages/scoped
|
|
115
|
-
copy: `
|
|
116
|
-
replace: `
|
|
158
|
+
default: "ui5nps scope.testPages.clean scope.testPages.copy scope.testPages.replace",
|
|
159
|
+
"clean": `ui5nps-script "${LIB}/rimraf/rimraf.js test/pages/scoped`,
|
|
160
|
+
copy: `ui5nps-script "${LIB}copy-and-watch/index.js" --silent "test/pages/**/*" test/pages/scoped`,
|
|
161
|
+
replace: `ui5nps-script "${LIB}scoping/scope-test-pages.js" test/pages/scoped demo`,
|
|
117
162
|
},
|
|
118
|
-
watchWithBundle: '
|
|
119
|
-
watch: '
|
|
120
|
-
bundle: `
|
|
163
|
+
watchWithBundle: 'ui5nps-p scope.watch scope.bundle', // concurently
|
|
164
|
+
watch: 'ui5nps-p watch.templates watch.props watch.styles', // concurently
|
|
165
|
+
bundle: `ui5nps-script ${LIB}dev-server/dev-server.mjs ${viteConfig}`,
|
|
121
166
|
},
|
|
122
167
|
generateAPI: {
|
|
123
|
-
default: "
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
jsdoc: `jsdoc -c "${LIB}/jsdoc/configTypescript.json"`,
|
|
127
|
-
cleanup: "rimraf jsdoc-dist/"
|
|
168
|
+
default: tsOption ? "ui5nps generateAPI.generateCEM generateAPI.validateCEM" : "",
|
|
169
|
+
generateCEM: `ui5nps-script "${LIB}cem/cem.js" analyze --config "${LIB}cem/custom-elements-manifest.config.mjs"`,
|
|
170
|
+
validateCEM: `ui5nps-script "${LIB}cem/validate.js"`,
|
|
128
171
|
},
|
|
129
172
|
};
|
|
130
173
|
|
|
@@ -1,21 +1 @@
|
|
|
1
|
-
|
|
2
|
-
const postcssCSStoESM = require('../lib/postcss-css-to-esm/index.js');
|
|
3
|
-
const cssnano = require('cssnano');
|
|
4
|
-
const fs = require("fs");
|
|
5
|
-
|
|
6
|
-
const packageName = JSON.parse(fs.readFileSync("./package.json")).name;
|
|
7
|
-
|
|
8
|
-
module.exports = {
|
|
9
|
-
plugins: [
|
|
10
|
-
postcssImport(),
|
|
11
|
-
cssnano({
|
|
12
|
-
preset: [
|
|
13
|
-
'default', {
|
|
14
|
-
mergeLonghand: false, // https://github.com/cssnano/cssnano/issues/675
|
|
15
|
-
mergeRules: false, // https://github.com/cssnano/cssnano/issues/730
|
|
16
|
-
},
|
|
17
|
-
]
|
|
18
|
-
}),
|
|
19
|
-
postcssCSStoESM({toReplace: 'src', includeDefaultTheme: true, packageName}),
|
|
20
|
-
]
|
|
21
|
-
};
|
|
1
|
+
module.exports = {}
|
|
@@ -1,26 +1 @@
|
|
|
1
|
-
|
|
2
|
-
const combineSelectors = require('../lib/postcss-combine-duplicated-selectors/index.js');
|
|
3
|
-
const postcssCSStoJSON = require('../lib/postcss-css-to-json/index.js');
|
|
4
|
-
const postcssCSStoESM = require('../lib/postcss-css-to-esm/index.js');
|
|
5
|
-
const cssnano = require('cssnano');
|
|
6
|
-
const fs = require("fs");
|
|
7
|
-
|
|
8
|
-
const packageName = JSON.parse(fs.readFileSync("./package.json")).name;
|
|
9
|
-
|
|
10
|
-
module.exports = {
|
|
11
|
-
plugins: [
|
|
12
|
-
postcssImport(),
|
|
13
|
-
combineSelectors({
|
|
14
|
-
removeDuplicatedProperties: true
|
|
15
|
-
}),
|
|
16
|
-
cssnano({
|
|
17
|
-
preset: [
|
|
18
|
-
'default', {
|
|
19
|
-
mergeLonghand: false, // https://github.com/cssnano/cssnano/issues/675
|
|
20
|
-
},
|
|
21
|
-
]
|
|
22
|
-
},),
|
|
23
|
-
postcssCSStoJSON({toReplace: 'src', packageName}),
|
|
24
|
-
postcssCSStoESM({toReplace: 'src', packageName}),
|
|
25
|
-
]
|
|
26
|
-
};
|
|
1
|
+
module.exports = {};
|
|
@@ -1,12 +1,9 @@
|
|
|
1
1
|
// vite.config.js
|
|
2
|
-
const
|
|
3
|
-
const virtualIndex = require("../lib/dev-server/virtual-index-html-plugin.js");
|
|
2
|
+
const virtualIndex = require('../lib/dev-server/virtual-index-html-plugin.js');
|
|
4
3
|
|
|
5
|
-
module.exports =
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
}
|
|
12
|
-
});
|
|
4
|
+
module.exports = {
|
|
5
|
+
build: {
|
|
6
|
+
emptyOutDir: false,
|
|
7
|
+
},
|
|
8
|
+
plugins: [virtualIndex()],
|
|
9
|
+
};
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
const dns = require("node:dns");
|
|
2
|
+
const assert = require("chai").assert;
|
|
3
|
+
|
|
1
4
|
exports.config = {
|
|
2
5
|
//
|
|
3
6
|
// ====================
|
|
@@ -56,7 +59,16 @@ exports.config = {
|
|
|
56
59
|
'goog:chromeOptions': {
|
|
57
60
|
// to run chrome headless the following flags are required
|
|
58
61
|
// (see https://developers.google.com/web/updates/2017/04/headless-chrome)
|
|
59
|
-
args: [
|
|
62
|
+
args: [
|
|
63
|
+
'--headless',
|
|
64
|
+
'--disable-search-engine-choice-screen',
|
|
65
|
+
'--start-maximized',
|
|
66
|
+
'--no-sandbox',
|
|
67
|
+
'--disable-gpu',
|
|
68
|
+
'--disable-infobars',
|
|
69
|
+
'--disable-extensions',
|
|
70
|
+
'--disable-dev-shm-usage',
|
|
71
|
+
],
|
|
60
72
|
// args: ['--disable-gpu'],
|
|
61
73
|
}
|
|
62
74
|
}],
|
|
@@ -99,8 +111,7 @@ exports.config = {
|
|
|
99
111
|
// Services take over a specific job you don't want to take care of. They enhance
|
|
100
112
|
// your test setup with almost no effort. Unlike plugins, they don't add new
|
|
101
113
|
// commands. Instead, they hook themselves up into the test process.
|
|
102
|
-
services: ['chromedriver', '
|
|
103
|
-
['static-server', {
|
|
114
|
+
services: ['chromedriver', ['static-server', {
|
|
104
115
|
folders: [
|
|
105
116
|
{ mount: '/', path: './dist' },
|
|
106
117
|
],
|
|
@@ -153,6 +164,9 @@ exports.config = {
|
|
|
153
164
|
*/
|
|
154
165
|
// beforeSession: function (config, capabilities, specs) {
|
|
155
166
|
// },
|
|
167
|
+
beforeSession: () => {
|
|
168
|
+
dns.setDefaultResultOrder('ipv4first');
|
|
169
|
+
},
|
|
156
170
|
/**
|
|
157
171
|
* Gets executed before test execution begins. At this point you can access to all global
|
|
158
172
|
* variables like `browser`. It is the perfect place to define custom commands.
|
|
@@ -223,12 +237,11 @@ exports.config = {
|
|
|
223
237
|
}, this, attrName);
|
|
224
238
|
}, true);
|
|
225
239
|
|
|
226
|
-
await browser.addCommand("
|
|
227
|
-
return browser.executeAsync(
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
}, false);
|
|
240
|
+
await browser.addCommand("matches", async function(selector) {
|
|
241
|
+
return browser.executeAsync((elem, selector, done) => {
|
|
242
|
+
done(elem.matches(selector));
|
|
243
|
+
}, this, selector);
|
|
244
|
+
}, true);
|
|
232
245
|
|
|
233
246
|
await browser.addLocatorStrategy('activeElement', (selector) => {
|
|
234
247
|
return document.querySelector(selector).shadowRoot.activeElement;
|
|
@@ -245,11 +258,11 @@ exports.config = {
|
|
|
245
258
|
"$$",
|
|
246
259
|
"getAttribute",
|
|
247
260
|
"hasAttribute", // custom
|
|
261
|
+
"matches", // custom
|
|
248
262
|
"getCSSProperty",
|
|
249
263
|
"getHTML",
|
|
250
264
|
"getProperty",
|
|
251
265
|
"getSize",
|
|
252
|
-
"getStaticAreaItemClassName", // custom
|
|
253
266
|
"getText",
|
|
254
267
|
"getValue",
|
|
255
268
|
"hasClass", // custom
|
|
@@ -261,7 +274,7 @@ exports.config = {
|
|
|
261
274
|
"isFocusedDeep", // custom
|
|
262
275
|
"isFocusedDeepElement", // custom
|
|
263
276
|
"shadow$",
|
|
264
|
-
"shadow$$"
|
|
277
|
+
"shadow$$"
|
|
265
278
|
];
|
|
266
279
|
if (waitFor.includes(commandName)) {
|
|
267
280
|
await browser.executeAsync(function (done) {
|
|
@@ -298,8 +311,17 @@ exports.config = {
|
|
|
298
311
|
* Function to be executed after a test (in Mocha/Jasmine) or a step (in Cucumber) starts.
|
|
299
312
|
* @param {Object} test test details
|
|
300
313
|
*/
|
|
301
|
-
|
|
302
|
-
|
|
314
|
+
afterTest: async function (test) {
|
|
315
|
+
// fetch the browser logs and fail the test if there are `console.error` messages with the `[UI5-FWK]` marker
|
|
316
|
+
const logs = await browser.getLogs('browser');
|
|
317
|
+
const severeLogs = logs
|
|
318
|
+
.filter(l => l.level === "SEVERE" && l.message.includes("[UI5-FWK]"))
|
|
319
|
+
.map(l => l.message);
|
|
320
|
+
|
|
321
|
+
if (severeLogs.length) {
|
|
322
|
+
test.callback(new Error(`[${test.title}]\n\n ${severeLogs.join("\n ")}`));
|
|
323
|
+
}
|
|
324
|
+
},
|
|
303
325
|
/**
|
|
304
326
|
* Hook that gets executed after the suite has ended
|
|
305
327
|
* @param {Object} suite suite details
|
|
@@ -381,8 +403,14 @@ exports.config = {
|
|
|
381
403
|
* @param {Array.<Object>} capabilities list of capabilities details
|
|
382
404
|
* @param {<Object>} results object containing test results
|
|
383
405
|
*/
|
|
384
|
-
|
|
385
|
-
|
|
406
|
+
onComplete: function (exitCode, config, capabilities, results) {
|
|
407
|
+
// The results object looks like: { finished: 0, passed: 0, retries: 0, failed: 0 }.
|
|
408
|
+
// If all values are 0, consider that no tests were found or executed.
|
|
409
|
+
if (exitCode === 1 && Object.values(results).every(result => result === 0)) {
|
|
410
|
+
console.log("✅ No specs were found or executed – treating as success.");
|
|
411
|
+
process.exit(0);
|
|
412
|
+
}
|
|
413
|
+
}
|
|
386
414
|
/**
|
|
387
415
|
* Gets executed when a refresh happens.
|
|
388
416
|
* @param {String} oldSessionId session ID of the old session
|
package/icons-collection/nps.js
CHANGED
|
@@ -4,35 +4,37 @@ const LIB = path.join(__dirname, `../lib/`);
|
|
|
4
4
|
|
|
5
5
|
const createIconImportsCommand = (options) => {
|
|
6
6
|
if (!options.versions) {
|
|
7
|
-
return `
|
|
7
|
+
return `ui5nps-script "${LIB}/create-icons/index.js" "${options.collectionName}"`;
|
|
8
8
|
}
|
|
9
9
|
|
|
10
|
-
const command
|
|
10
|
+
const command = { default: "ui5nps" };
|
|
11
11
|
options.versions.forEach((v) => {
|
|
12
12
|
command.default += ` build.icons.create${v}`;
|
|
13
|
-
command[`create${v}`] = `
|
|
13
|
+
command[`create${v}`] = `ui5nps-script "${LIB}/create-icons/index.js" "${options.collectionName}" "${v}"`;
|
|
14
14
|
});
|
|
15
15
|
|
|
16
16
|
return command;
|
|
17
17
|
}
|
|
18
18
|
|
|
19
|
+
const hashesCheck = cmd => `(node "${LIB}/icons-hash/icons-hash.mjs" check) || (${cmd} && node "${LIB}/icons-hash/icons-hash.mjs" save)`;
|
|
20
|
+
|
|
19
21
|
const copyIconAssetsCommand = (options) => {
|
|
20
22
|
if (!options.versions) {
|
|
21
|
-
return
|
|
22
|
-
default: "
|
|
23
|
-
"json-imports": `
|
|
24
|
-
"icon-collection": `
|
|
23
|
+
return {
|
|
24
|
+
default: "ui5nps copy.json-imports copy.icon-collection",
|
|
25
|
+
"json-imports": `ui5nps-script "${LIB}/copy-and-watch/index.js" --silent "src/**/*.js" dist/`,
|
|
26
|
+
"icon-collection": `ui5nps-script "${LIB}/copy-and-watch/index.js" --silent "src/*.json" src/generated/assets/`,
|
|
25
27
|
}
|
|
26
28
|
}
|
|
27
29
|
|
|
28
|
-
const command
|
|
29
|
-
default: "
|
|
30
|
-
"json-imports": `
|
|
30
|
+
const command = {
|
|
31
|
+
default: "ui5nps copy.json-imports ",
|
|
32
|
+
"json-imports": `ui5nps-script "${LIB}/copy-and-watch/index.js" --silent "src/**/*.js" dist/`,
|
|
31
33
|
};
|
|
32
34
|
|
|
33
35
|
options.versions.forEach((v) => {
|
|
34
36
|
command.default += ` copy.icon-collection${v}`;
|
|
35
|
-
command[`icon-collection${v}`] = `
|
|
37
|
+
command[`icon-collection${v}`] = `ui5nps-script "${LIB}/copy-and-watch/index.js" --silent "src/${v}/*.json" src/generated/assets/${v}/`;
|
|
36
38
|
});
|
|
37
39
|
|
|
38
40
|
return command;
|
|
@@ -41,24 +43,35 @@ const copyIconAssetsCommand = (options) => {
|
|
|
41
43
|
const getScripts = (options) => {
|
|
42
44
|
const createJSImportsCmd = createIconImportsCommand(options);
|
|
43
45
|
const copyAssetsCmd = copyIconAssetsCommand(options);
|
|
46
|
+
const tsCommand = !options.legacy ? "tsc --build" : "";
|
|
47
|
+
const tsOption = !options.legacy;
|
|
44
48
|
|
|
45
49
|
const scripts = {
|
|
46
|
-
|
|
50
|
+
__ui5envs: {
|
|
51
|
+
UI5_TS: `${tsOption}`,
|
|
52
|
+
},
|
|
53
|
+
clean: {
|
|
54
|
+
default: "ui5nps clean.generated clean.dist",
|
|
55
|
+
"generated": `ui5nps-script "${LIB}/rimraf/rimraf.js src/generated`,
|
|
56
|
+
"dist": `ui5nps-script "${LIB}/rimraf/rimraf.js dist`,
|
|
57
|
+
},
|
|
47
58
|
copy: copyAssetsCmd,
|
|
59
|
+
generate: hashesCheck(`ui5nps clean copy build.i18n build.icons build.jsonImports copyjson`),
|
|
60
|
+
copyjson: `ui5nps-script "${LIB}copy-and-watch/index.js" "src/generated/**/*.json" dist/generated`,
|
|
48
61
|
build: {
|
|
49
|
-
default: `
|
|
62
|
+
default: hashesCheck(`ui5nps clean copy build.i18n typescript build.icons build.jsonImports`),
|
|
50
63
|
i18n: {
|
|
51
|
-
default: "
|
|
52
|
-
defaultsjs: `
|
|
53
|
-
json: `
|
|
64
|
+
default: "ui5nps build.i18n.defaultsjs build.i18n.json",
|
|
65
|
+
defaultsjs: `ui5nps-script "${LIB}/i18n/defaults.js" src/i18n src/generated/i18n`,
|
|
66
|
+
json: `ui5nps-script "${LIB}/i18n/toJSON.js" src/i18n src/generated/assets/i18n`,
|
|
54
67
|
},
|
|
55
68
|
jsonImports: {
|
|
56
|
-
default: "
|
|
57
|
-
i18n: `
|
|
69
|
+
default: "ui5nps build.jsonImports.i18n",
|
|
70
|
+
i18n: `ui5nps-script "${LIB}/generate-json-imports/i18n.js" src/generated/assets/i18n src/generated/json-imports`,
|
|
58
71
|
},
|
|
59
72
|
icons: createJSImportsCmd,
|
|
60
73
|
},
|
|
61
|
-
typescript:
|
|
74
|
+
typescript: tsCommand,
|
|
62
75
|
};
|
|
63
76
|
|
|
64
77
|
return scripts;
|