@ui5/webcomponents-tools 0.0.0-a3eca7ade → 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 +2343 -0
- package/LICENSE.txt +201 -0
- package/README.md +7 -10
- package/assets-meta.js +13 -8
- package/bin/dev.js +10 -8
- package/bin/ui5nps.js +301 -0
- package/components-package/eslint.js +66 -2
- package/components-package/nps.js +141 -80
- package/components-package/postcss.components.js +1 -21
- package/components-package/postcss.themes.js +1 -26
- package/components-package/vite.config.js +9 -0
- package/components-package/wdio.js +69 -17
- package/icons-collection/nps.js +32 -24
- 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 +133 -97
- package/lib/copy-list/index.js +27 -19
- package/lib/create-icons/index.js +131 -72
- package/lib/create-illustrations/index.js +174 -114
- 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.mjs +78 -0
- package/lib/dev-server/virtual-index-html-plugin.js +56 -0
- package/lib/eslint/eslint.js +44 -0
- package/lib/generate-js-imports/illustrations.js +87 -0
- package/lib/generate-json-imports/i18n.js +71 -69
- package/lib/generate-json-imports/themes.js +50 -48
- package/lib/hbs2lit/src/compiler.js +24 -4
- package/lib/hbs2lit/src/includesReplacer.js +5 -5
- package/lib/hbs2lit/src/litVisitor2.js +85 -22
- package/lib/hbs2lit/src/svgProcessor.js +12 -5
- package/lib/hbs2ui5/RenderTemplates/LitRenderer.js +39 -6
- package/lib/hbs2ui5/index.js +57 -24
- package/lib/i18n/defaults.js +76 -60
- package/lib/i18n/toJSON.js +47 -18
- package/lib/icons-hash/icons-hash.mjs +149 -0
- package/lib/postcss-combine-duplicated-selectors/index.js +185 -0
- 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 +11 -11
- package/lib/scoping/lint-src.js +8 -7
- package/lib/scoping/scope-test-pages.js +2 -1
- package/lib/test-runner/test-runner.js +79 -0
- package/lib/vite-bundler/vite-bundler.mjs +35 -0
- package/package.json +47 -43
- package/tsconfig.json +18 -0
- package/components-package/rollup-plugins/empty-module.js +0 -15
- package/components-package/rollup.js +0 -239
- package/components-package/wdio.sync.js +0 -360
- package/lib/documentation/index.js +0 -165
- package/lib/documentation/templates/api-component-since.js +0 -3
- package/lib/documentation/templates/api-css-variables-section.js +0 -24
- package/lib/documentation/templates/api-events-section.js +0 -35
- package/lib/documentation/templates/api-methods-section.js +0 -26
- package/lib/documentation/templates/api-properties-section.js +0 -42
- package/lib/documentation/templates/api-slots-section.js +0 -28
- package/lib/documentation/templates/template.js +0 -39
- package/lib/esm-abs-to-rel/index.js +0 -54
- package/lib/hash/config.js +0 -10
- package/lib/hash/generate.js +0 -19
- package/lib/hash/upToDate.js +0 -31
- package/lib/jsdoc/config.json +0 -29
- package/lib/jsdoc/plugin.js +0 -2436
- package/lib/jsdoc/template/publish.js +0 -4112
- package/lib/polyfill-placeholder/index.js +0 -5
- package/lib/postcss-css-to-esm/index.js +0 -45
- package/lib/postcss-css-to-json/index.js +0 -36
- package/lib/postcss-new-files/index.js +0 -36
- package/lib/replace-global-core/index.js +0 -20
- package/lib/serve/index.js +0 -46
- package/lib/serve/serve.json +0 -3
- package/package-lock.json +0 -48
|
@@ -1,3 +1,65 @@
|
|
|
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 = {
|
|
11
|
+
files: ["*.ts"],
|
|
12
|
+
parser: "@typescript-eslint/parser",
|
|
13
|
+
plugins: ["@typescript-eslint"],
|
|
14
|
+
extends: [
|
|
15
|
+
"plugin:@typescript-eslint/recommended",
|
|
16
|
+
"plugin:@typescript-eslint/recommended-requiring-type-checking"
|
|
17
|
+
],
|
|
18
|
+
parserOptions: {
|
|
19
|
+
"project": [
|
|
20
|
+
"./tsconfig.json"
|
|
21
|
+
],
|
|
22
|
+
EXPERIMENTAL_useSourceOfProjectReferenceRedirect: true,
|
|
23
|
+
},
|
|
24
|
+
rules: {
|
|
25
|
+
"no-shadow": "off",
|
|
26
|
+
"@typescript-eslint/consistent-type-imports": "error",
|
|
27
|
+
"import/consistent-type-specifier-style": ["error", "prefer-top-level"],
|
|
28
|
+
"@typescript-eslint/no-shadow": ["error"],
|
|
29
|
+
"@typescript-eslint/no-unsafe-member-access": "off",
|
|
30
|
+
"@typescript-eslint/no-floating-promises": "off",
|
|
31
|
+
"@typescript-eslint/no-explicit-any": "off",
|
|
32
|
+
"@typescript-eslint/no-unsafe-assignment": "off",
|
|
33
|
+
"@typescript-eslint/ban-ts-comment": "off",
|
|
34
|
+
"@typescript-eslint/no-unsafe-call": "off",
|
|
35
|
+
"@typescript-eslint/no-non-null-assertion": "off",
|
|
36
|
+
"@typescript-eslint/no-empty-function": "off",
|
|
37
|
+
"@typescript-eslint/no-empty-interface": "off",
|
|
38
|
+
"lines-between-class-members": "off",
|
|
39
|
+
}
|
|
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
|
+
|
|
1
63
|
module.exports = {
|
|
2
64
|
"env": {
|
|
3
65
|
"browser": true,
|
|
@@ -5,6 +67,7 @@ module.exports = {
|
|
|
5
67
|
},
|
|
6
68
|
"root": true,
|
|
7
69
|
"extends": "airbnb-base",
|
|
70
|
+
"overrides": tsMode ? getTsModeOverrides() : [],
|
|
8
71
|
"parserOptions": {
|
|
9
72
|
"ecmaVersion": 2018,
|
|
10
73
|
"sourceType": "module"
|
|
@@ -47,6 +110,7 @@ module.exports = {
|
|
|
47
110
|
"curly": [2, "all"],
|
|
48
111
|
// "default-case": 1, // removed for UI5 WebComponents
|
|
49
112
|
"import/extensions": ["error", "always"], // override for UI5 WebComponents
|
|
113
|
+
"import/order": "off",
|
|
50
114
|
"no-alert": 2,
|
|
51
115
|
"no-caller": 2,
|
|
52
116
|
"no-div-regex": 2,
|
|
@@ -88,7 +152,7 @@ module.exports = {
|
|
|
88
152
|
"no-shadow-restricted-names": 2,
|
|
89
153
|
"no-undef-init": 2,
|
|
90
154
|
"no-undef": 2,
|
|
91
|
-
"no-unused-vars": [2, {"vars":"all", "args":"none"}],
|
|
155
|
+
"no-unused-vars": [2, { "vars": "all", "args": "none" }],
|
|
92
156
|
|
|
93
157
|
"brace-style": [2, "1tbs", { "allowSingleLine": true }],
|
|
94
158
|
"camelcase": [1, { "properties": "never" }], // added for UI5 WebComponents
|
|
@@ -104,7 +168,7 @@ module.exports = {
|
|
|
104
168
|
"no-new-object": 2,
|
|
105
169
|
"no-spaced-func": 2,
|
|
106
170
|
"quote-props": [2, "as-needed", { "keywords": true, "unnecessary": false }],
|
|
107
|
-
"semi-spacing": [1, {"before": false, "after": true}],
|
|
171
|
+
"semi-spacing": [1, { "before": false, "after": true }],
|
|
108
172
|
"semi": 2,
|
|
109
173
|
"keyword-spacing": 2,
|
|
110
174
|
"space-infix-ops": 2,
|
|
@@ -1,113 +1,174 @@
|
|
|
1
1
|
const path = require("path");
|
|
2
2
|
const fs = require("fs");
|
|
3
|
-
|
|
4
3
|
const LIB = path.join(__dirname, `../lib/`);
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const
|
|
4
|
+
let websiteBaseUrl = "/";
|
|
5
|
+
|
|
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
|
|
|
9
22
|
const getScripts = (options) => {
|
|
23
|
+
// The script creates all JS modules (dist/illustrations/{illustrationName}.js) out of the existing SVGs
|
|
24
|
+
const illustrationsData = options.illustrationsData || [];
|
|
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
|
+
});
|
|
10
38
|
|
|
11
|
-
const port = options.port || 8080; // preferred port
|
|
12
|
-
const portStep = options.portStep || 1; // step to check for available ports, if preferred port is already used
|
|
13
|
-
let illustrations = options.illustrationsData || [];
|
|
14
39
|
|
|
15
|
-
|
|
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
|
+
}
|
|
16
47
|
|
|
17
|
-
|
|
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
|
+
}
|
|
56
|
+
|
|
57
|
+
let viteConfig;
|
|
58
|
+
if (fs.existsSync("config/vite.config.js")) {
|
|
59
|
+
// old project setup where config file is in separate folder
|
|
60
|
+
viteConfig = "-c config/vite.config.js";
|
|
61
|
+
} else if (fs.existsSync("vite.config.js")) {
|
|
62
|
+
// preferred way of custom configuration in root project folder
|
|
63
|
+
viteConfig = "";
|
|
64
|
+
} else {
|
|
65
|
+
// no custom configuration - use default from tools project
|
|
66
|
+
viteConfig = `-c "${require.resolve("@ui5/webcomponents-tools/components-package/vite.config.js")}"`;
|
|
67
|
+
}
|
|
18
68
|
|
|
19
69
|
const scripts = {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
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
|
+
},
|
|
23
88
|
prepare: {
|
|
24
|
-
default:
|
|
25
|
-
|
|
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,
|
|
26
93
|
},
|
|
27
94
|
build: {
|
|
28
|
-
default: "
|
|
29
|
-
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` : "",
|
|
30
97
|
styles: {
|
|
31
|
-
default:
|
|
32
|
-
themes: "
|
|
33
|
-
|
|
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`,
|
|
34
103
|
},
|
|
35
104
|
i18n: {
|
|
36
|
-
default: "
|
|
37
|
-
defaultsjs: `
|
|
38
|
-
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`,
|
|
39
108
|
},
|
|
40
109
|
jsonImports: {
|
|
41
|
-
default: "
|
|
42
|
-
themes: `
|
|
43
|
-
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`,
|
|
44
113
|
},
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
api: `jsdoc -c "${LIB}/jsdoc/config.json"`,
|
|
49
|
-
docs: `node "${LIB}/documentation/index.js" dist/api.json`,
|
|
114
|
+
jsImports: {
|
|
115
|
+
default: "ui5nps build.jsImports.illustrationsLoaders",
|
|
116
|
+
illustrationsLoaders: createIllustrationsLoadersScript,
|
|
50
117
|
},
|
|
51
|
-
|
|
118
|
+
bundle: `ui5nps-script "${LIB}vite-bundler/vite-bundler.mjs" ${viteConfig} --mode testing --base ${websiteBaseUrl}`,
|
|
119
|
+
bundle2: ``,
|
|
120
|
+
illustrations: createIllustrationsJSImportsScript,
|
|
52
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`,
|
|
53
125
|
copy: {
|
|
54
|
-
default: "
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
props: `node "${LIB}/copy-and-watch/index.js" --silent "src/**/*.properties" dist/`,
|
|
58
|
-
test: `node "${LIB}/copy-and-watch/index.js" --silent "test/**/*.*" dist/test-resources`,
|
|
59
|
-
"webcomponents-polyfill": `node "${LIB}/copy-and-watch/index.js" --silent "${polyfillPath}" dist/webcomponentsjs/`,
|
|
60
|
-
"webcomponents-polyfill-placeholder": `node "${LIB}/polyfill-placeholder/index.js"`
|
|
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/` : "",
|
|
61
129
|
},
|
|
62
130
|
watch: {
|
|
63
|
-
default:
|
|
64
|
-
|
|
65
|
-
src: '
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
bundle: {
|
|
69
|
-
default: 'rollup --config config/rollup.config.js -w --environment DEV,DEPLOY_PUBLIC_PATH:/resources/',
|
|
70
|
-
es5: 'rollup --config config/rollup.config.js -w --environment ES5_BUILD,DEV,DEPLOY_PUBLIC_PATH:/resources/'
|
|
71
|
-
},
|
|
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}`,
|
|
72
137
|
styles: {
|
|
73
|
-
default: '
|
|
74
|
-
themes: '
|
|
75
|
-
components:
|
|
76
|
-
default: 'concurrently "nps watch.styles.components.existingFiles" "nps watch.styles.components.newFiles"',
|
|
77
|
-
existingFiles: `nps "build.styles.components -w"`,
|
|
78
|
-
newFiles: `node "${LIB}/postcss-new-files/index.js" --srcFiles="src/themes/*.css"`,
|
|
79
|
-
},
|
|
138
|
+
default: 'ui5nps-p watch.styles.themes watch.styles.components', // concurently
|
|
139
|
+
themes: 'ui5nps build.styles.themesWithWatch',
|
|
140
|
+
components: `ui5nps build.styles.componentsWithWatch`,
|
|
80
141
|
},
|
|
81
|
-
templates:
|
|
82
|
-
|
|
83
|
-
i18n: 'chokidar "src/i18n/messagebundle.properties" -c "nps build.i18n.defaultsjs"'
|
|
84
|
-
},
|
|
85
|
-
dev: {
|
|
86
|
-
default: 'concurrently "nps serve" "nps watch"',
|
|
87
|
-
es5: 'concurrently "nps serve" "nps watch.es5"'
|
|
88
|
-
},
|
|
89
|
-
start: "nps prepare dev",
|
|
90
|
-
serve: `node "${LIB}/serve/index.js" --dir="dist/" --port=${port} --portStep=${portStep} --packageName="${packageName}"`,
|
|
91
|
-
test: {
|
|
92
|
-
// --success first - report the exit code of the test run (first command to finish), as serve is always terminated and has a non-0 exit code
|
|
93
|
-
default: 'concurrently "nps serve" "nps test.run" --kill-others --success first',
|
|
94
|
-
run: "cross-env WDIO_LOG_LEVEL=error wdio config/wdio.conf.js",
|
|
95
|
-
spec: "wdio run config/wdio.conf.js",
|
|
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"`
|
|
96
144
|
},
|
|
97
|
-
|
|
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",
|
|
98
154
|
scope: {
|
|
99
|
-
prepare: "
|
|
100
|
-
lint: `
|
|
155
|
+
prepare: "ui5nps scope.lint scope.testPages",
|
|
156
|
+
lint: `ui5nps-script "${LIB}scoping/lint-src.js"`,
|
|
101
157
|
testPages: {
|
|
102
|
-
default: "
|
|
103
|
-
clean: "rimraf
|
|
104
|
-
copy: `
|
|
105
|
-
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`,
|
|
106
162
|
},
|
|
107
|
-
|
|
108
|
-
watch: '
|
|
109
|
-
bundle:
|
|
110
|
-
}
|
|
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}`,
|
|
166
|
+
},
|
|
167
|
+
generateAPI: {
|
|
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"`,
|
|
171
|
+
},
|
|
111
172
|
};
|
|
112
173
|
|
|
113
174
|
return scripts;
|
|
@@ -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('postcss-combine-duplicated-selectors');
|
|
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,3 +1,6 @@
|
|
|
1
|
+
const dns = require("node:dns");
|
|
2
|
+
const assert = require("chai").assert;
|
|
3
|
+
|
|
1
4
|
exports.config = {
|
|
2
5
|
//
|
|
3
6
|
// ====================
|
|
@@ -50,13 +53,22 @@ exports.config = {
|
|
|
50
53
|
// maxInstances can get overwritten per capability. So if you have an in-house Selenium
|
|
51
54
|
// grid with only 5 firefox instances available you can make sure that not more than
|
|
52
55
|
// 5 instances get started at a time.
|
|
53
|
-
maxInstances:
|
|
56
|
+
maxInstances: 5,
|
|
54
57
|
//
|
|
55
58
|
browserName: 'chrome',
|
|
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
|
}],
|
|
@@ -82,7 +94,7 @@ exports.config = {
|
|
|
82
94
|
// with `/`, the base url gets prepended, not including the path portion of your baseUrl.
|
|
83
95
|
// If your `url` parameter starts without a scheme or `/` (like `some/path`), the base url
|
|
84
96
|
// gets prepended directly.
|
|
85
|
-
baseUrl:
|
|
97
|
+
baseUrl: 'http://localhost:4567', // This is important since WDIO 7+ does not accept an empty string for baseUrl
|
|
86
98
|
path: '',
|
|
87
99
|
//
|
|
88
100
|
// Default timeout for all waitFor* commands.
|
|
@@ -99,7 +111,13 @@ 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'
|
|
114
|
+
services: ['chromedriver', ['static-server', {
|
|
115
|
+
folders: [
|
|
116
|
+
{ mount: '/', path: './dist' },
|
|
117
|
+
],
|
|
118
|
+
port: '4567',
|
|
119
|
+
}],
|
|
120
|
+
],
|
|
103
121
|
// options
|
|
104
122
|
chromeDriverArgs: ['--port=9515'], // default
|
|
105
123
|
// Framework you want to run your specs with.
|
|
@@ -146,6 +164,9 @@ exports.config = {
|
|
|
146
164
|
*/
|
|
147
165
|
// beforeSession: function (config, capabilities, specs) {
|
|
148
166
|
// },
|
|
167
|
+
beforeSession: () => {
|
|
168
|
+
dns.setDefaultResultOrder('ipv4first');
|
|
169
|
+
},
|
|
149
170
|
/**
|
|
150
171
|
* Gets executed before test execution begins. At this point you can access to all global
|
|
151
172
|
* variables like `browser`. It is the perfect place to define custom commands.
|
|
@@ -210,12 +231,17 @@ exports.config = {
|
|
|
210
231
|
}, this, className);
|
|
211
232
|
}, true);
|
|
212
233
|
|
|
213
|
-
await browser.addCommand("
|
|
214
|
-
return browser.executeAsync(
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
234
|
+
await browser.addCommand("hasAttribute", async function(attrName) {
|
|
235
|
+
return browser.executeAsync((elem, attrName, done) => {
|
|
236
|
+
done(elem.hasAttribute(attrName));
|
|
237
|
+
}, this, attrName);
|
|
238
|
+
}, true);
|
|
239
|
+
|
|
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);
|
|
219
245
|
|
|
220
246
|
await browser.addLocatorStrategy('activeElement', (selector) => {
|
|
221
247
|
return document.querySelector(selector).shadowRoot.activeElement;
|
|
@@ -231,11 +257,12 @@ exports.config = {
|
|
|
231
257
|
"$",
|
|
232
258
|
"$$",
|
|
233
259
|
"getAttribute",
|
|
260
|
+
"hasAttribute", // custom
|
|
261
|
+
"matches", // custom
|
|
234
262
|
"getCSSProperty",
|
|
235
263
|
"getHTML",
|
|
236
264
|
"getProperty",
|
|
237
265
|
"getSize",
|
|
238
|
-
"getStaticAreaItemClassName", // custom
|
|
239
266
|
"getText",
|
|
240
267
|
"getValue",
|
|
241
268
|
"hasClass", // custom
|
|
@@ -247,7 +274,7 @@ exports.config = {
|
|
|
247
274
|
"isFocusedDeep", // custom
|
|
248
275
|
"isFocusedDeepElement", // custom
|
|
249
276
|
"shadow$",
|
|
250
|
-
"shadow$$"
|
|
277
|
+
"shadow$$"
|
|
251
278
|
];
|
|
252
279
|
if (waitFor.includes(commandName)) {
|
|
253
280
|
await browser.executeAsync(function (done) {
|
|
@@ -284,8 +311,17 @@ exports.config = {
|
|
|
284
311
|
* Function to be executed after a test (in Mocha/Jasmine) or a step (in Cucumber) starts.
|
|
285
312
|
* @param {Object} test test details
|
|
286
313
|
*/
|
|
287
|
-
|
|
288
|
-
|
|
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
|
+
},
|
|
289
325
|
/**
|
|
290
326
|
* Hook that gets executed after the suite has ended
|
|
291
327
|
* @param {Object} suite suite details
|
|
@@ -316,7 +352,6 @@ exports.config = {
|
|
|
316
352
|
"click",
|
|
317
353
|
"doubleClick",
|
|
318
354
|
"dragAndDrop",
|
|
319
|
-
"keys",
|
|
320
355
|
"pause",
|
|
321
356
|
"removeAttribute", // custom
|
|
322
357
|
"scrollIntoView",
|
|
@@ -327,10 +362,21 @@ exports.config = {
|
|
|
327
362
|
"touchAction",
|
|
328
363
|
"url",
|
|
329
364
|
];
|
|
365
|
+
|
|
366
|
+
const waitForWithDelay = [
|
|
367
|
+
"keys",
|
|
368
|
+
];
|
|
369
|
+
|
|
330
370
|
if (waitFor.includes(commandName)) {
|
|
331
371
|
await browser.executeAsync(function (done) {
|
|
332
372
|
window["sap-ui-webcomponents-bundle"].renderFinished().then(done);
|
|
333
373
|
});
|
|
374
|
+
} else if (waitForWithDelay.includes(commandName)) {
|
|
375
|
+
await browser.executeAsync(function (done) {
|
|
376
|
+
setTimeout(() => {
|
|
377
|
+
window["sap-ui-webcomponents-bundle"].renderFinished().then(done);
|
|
378
|
+
}, 10);
|
|
379
|
+
});
|
|
334
380
|
}
|
|
335
381
|
},
|
|
336
382
|
/**
|
|
@@ -357,8 +403,14 @@ exports.config = {
|
|
|
357
403
|
* @param {Array.<Object>} capabilities list of capabilities details
|
|
358
404
|
* @param {<Object>} results object containing test results
|
|
359
405
|
*/
|
|
360
|
-
|
|
361
|
-
|
|
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
|
+
}
|
|
362
414
|
/**
|
|
363
415
|
* Gets executed when a refresh happens.
|
|
364
416
|
* @param {String} oldSessionId session ID of the old session
|