@ui5/webcomponents-tools 0.0.0-dc606098a → 0.0.0-ddc5fe31b
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 +908 -0
- package/README.md +6 -6
- package/assets-meta.js +29 -3
- package/bin/dev.js +12 -1
- package/components-package/eslint.js +36 -0
- package/components-package/nps.js +119 -44
- package/components-package/postcss.components.js +1 -21
- package/components-package/postcss.themes.js +1 -23
- package/components-package/vite.config.js +13 -0
- package/components-package/wdio.js +405 -297
- package/components-package/wdio.sync.js +368 -0
- package/icons-collection/nps.js +55 -12
- package/lib/amd-to-es6/index.js +104 -0
- package/lib/cem/custom-elements-manifest.config.mjs +482 -0
- package/lib/cem/event.mjs +131 -0
- package/lib/cem/schema-internal.json +1357 -0
- package/lib/cem/schema.json +1098 -0
- package/lib/cem/types-internal.d.ts +802 -0
- package/lib/cem/types.d.ts +736 -0
- package/lib/cem/utils.mjs +379 -0
- package/lib/cem/validate.js +65 -0
- package/lib/copy-and-watch/index.js +145 -0
- package/lib/copy-list/index.js +28 -0
- package/lib/create-icons/index.js +124 -54
- package/lib/create-illustrations/index.js +165 -0
- package/lib/create-new-component/index.js +72 -93
- package/lib/create-new-component/jsFileContentTemplate.js +73 -0
- package/lib/create-new-component/tsFileContentTemplate.js +71 -0
- package/lib/css-processors/css-processor-components.mjs +77 -0
- package/lib/css-processors/css-processor-themes.mjs +79 -0
- package/lib/css-processors/scope-variables.mjs +46 -0
- package/lib/css-processors/shared.mjs +76 -0
- package/lib/dev-server/custom-hot-update-plugin.js +39 -0
- package/lib/dev-server/dev-server.js +66 -0
- package/lib/dev-server/virtual-index-html-plugin.js +52 -0
- package/lib/generate-custom-elements-manifest/index.js +271 -0
- package/lib/generate-js-imports/illustrations.js +86 -0
- package/lib/generate-json-imports/i18n.js +80 -30
- package/lib/generate-json-imports/themes.js +70 -18
- package/lib/hbs2lit/index.js +2 -4
- package/lib/hbs2lit/src/compiler.js +30 -9
- package/lib/hbs2lit/src/includesReplacer.js +23 -17
- package/lib/hbs2lit/src/litVisitor2.js +125 -26
- package/lib/hbs2lit/src/svgProcessor.js +12 -5
- package/lib/hbs2ui5/RenderTemplates/LitRenderer.js +35 -7
- package/lib/hbs2ui5/index.js +69 -30
- package/lib/i18n/defaults.js +65 -57
- package/lib/i18n/toJSON.js +13 -12
- package/lib/jsdoc/config.json +1 -1
- package/lib/jsdoc/configTypescript.json +29 -0
- package/lib/jsdoc/plugin.js +65 -4
- package/lib/jsdoc/preprocess.js +146 -0
- package/lib/jsdoc/template/publish.js +32 -4
- package/lib/postcss-combine-duplicated-selectors/index.js +185 -0
- package/lib/scoping/get-all-tags.js +37 -0
- package/lib/scoping/lint-src.js +31 -0
- package/lib/scoping/missing-dependencies.js +65 -0
- package/lib/scoping/report-tags-usage.js +28 -0
- package/lib/scoping/scope-test-pages.js +41 -0
- package/lib/test-runner/test-runner.js +71 -0
- package/package.json +55 -54
- package/bin/init-ui5-package.js +0 -3
- package/components-package/rollup.js +0 -134
- package/components-package/serve.json +0 -3
- package/lib/documentation/index.js +0 -143
- 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 -40
- package/lib/documentation/templates/api-slots-section.js +0 -28
- package/lib/documentation/templates/template.js +0 -38
- package/lib/init-package/index.js +0 -119
- package/lib/init-package/resources/.eslintignore +0 -3
- package/lib/init-package/resources/bundle.es5.js +0 -25
- package/lib/init-package/resources/bundle.esm.js +0 -34
- package/lib/init-package/resources/config/.eslintrc.js +0 -1
- package/lib/init-package/resources/config/postcss.components/postcss.config.js +0 -1
- package/lib/init-package/resources/config/postcss.themes/postcss.config.js +0 -1
- package/lib/init-package/resources/config/rollup.config.js +0 -1
- package/lib/init-package/resources/config/wdio.conf.js +0 -1
- package/lib/init-package/resources/package-scripts.js +0 -11
- package/lib/init-package/resources/src/Assets.js +0 -5
- package/lib/init-package/resources/src/Demo.hbs +0 -1
- package/lib/init-package/resources/src/Demo.js +0 -56
- package/lib/init-package/resources/src/i18n/messagebundle.properties +0 -2
- package/lib/init-package/resources/src/i18n/messagebundle_de.properties +0 -1
- package/lib/init-package/resources/src/i18n/messagebundle_en.properties +0 -1
- package/lib/init-package/resources/src/i18n/messagebundle_es.properties +0 -1
- package/lib/init-package/resources/src/i18n/messagebundle_fr.properties +0 -1
- package/lib/init-package/resources/src/themes/Demo.css +0 -11
- package/lib/init-package/resources/src/themes/sap_belize/parameters-bundle.css +0 -3
- package/lib/init-package/resources/src/themes/sap_belize_hcb/parameters-bundle.css +0 -3
- package/lib/init-package/resources/src/themes/sap_belize_hcw/parameters-bundle.css +0 -3
- package/lib/init-package/resources/src/themes/sap_fiori_3/parameters-bundle.css +0 -3
- package/lib/init-package/resources/src/themes/sap_fiori_3_dark/parameters-bundle.css +0 -3
- package/lib/init-package/resources/test/pages/index.html +0 -51
- package/lib/init-package/resources/test/specs/Demo.spec.js +0 -12
- package/lib/postcss-css-to-esm/index.js +0 -42
- package/lib/postcss-css-to-json/index.js +0 -27
@@ -1,35 +0,0 @@
|
|
1
|
-
module.exports = {
|
2
|
-
template: `
|
3
|
-
{{#if events}}
|
4
|
-
<h3 class="comment-api-title space-top">Events</h3>
|
5
|
-
<p class="small-space-top" >This Web Component fires semantic events upon user interaction. You can bind to these events with the standard DOM APIs, such as <code>addEventListener</code>. </p>
|
6
|
-
|
7
|
-
<div class="small-space-top api-table">
|
8
|
-
<div class="head api-table-header-roll">
|
9
|
-
<div class="cell api-table-header-cell">Name</div>
|
10
|
-
<div class="cell api-table-header-cell">Description</div>
|
11
|
-
</div>
|
12
|
-
|
13
|
-
{{#each events}}
|
14
|
-
<div class="row {{checkEven @index}}">
|
15
|
-
<div class="cell api-table-content-cell api-table-content-cell-bold">{{this.name}}</div>
|
16
|
-
<div class="cell api-table-content-cell api-table-content-cell-description">
|
17
|
-
{{{this.description}}}
|
18
|
-
{{#if this.since}}
|
19
|
-
<div class="api-table-content-cell-bold api-table-content-cell-since">since v{{{this.since}}}</div>
|
20
|
-
{{/if}}
|
21
|
-
</div>
|
22
|
-
</div>
|
23
|
-
|
24
|
-
{{#each this.parameters}}
|
25
|
-
<tr class="api-table-event-param">
|
26
|
-
<div class="api-table-content-event-params-wrapper">
|
27
|
-
<div class="cell api-table-param-name api-table-content-cell api-table-content-cell-bold">{{this.name}}</div>
|
28
|
-
<div class="cell api-table-event-param-cell api-table-content-cell api-table-content-cell-description"><strong class="bold" >type:</strong> {{this.type}} <br/> <strong class="api-table-event-description bold">description:</strong> {{{this.description}}}</div>
|
29
|
-
</div>
|
30
|
-
</tr>
|
31
|
-
{{/each}}
|
32
|
-
{{/each}}
|
33
|
-
</div>
|
34
|
-
{{/if}}`
|
35
|
-
};
|
@@ -1,26 +0,0 @@
|
|
1
|
-
module.exports = {
|
2
|
-
template: `
|
3
|
-
{{#if methods}}
|
4
|
-
<h3 class="comment-api-title space-top">Methods</h3>
|
5
|
-
<p class="small-space-top" >This Web Component exposes public methods. You can invoke them directly on the Web Component instance.</p>
|
6
|
-
|
7
|
-
<div class="small-space-top api-table">
|
8
|
-
<div class="head api-table-header-roll">
|
9
|
-
<div class="cell api-table-header-cell">Name</div>
|
10
|
-
<div class="cell api-table-header-cell">Description</div>
|
11
|
-
</div>
|
12
|
-
|
13
|
-
{{#each methods}}
|
14
|
-
<div class="row {{checkEven @index}}">
|
15
|
-
<div class="cell api-table-content-cell api-table-content-cell-bold">{{this.name}}</div>
|
16
|
-
<div class="cell api-table-content-cell api-table-content-cell-description">{{{this.description}}}</div>
|
17
|
-
</div>
|
18
|
-
|
19
|
-
{{#each this.parameters}}
|
20
|
-
<div class="cell api-table-content-cell api-table-content-cell-bold api-table-param-name">{{this.name}}</div>
|
21
|
-
<div class="cell api-table-event-param-cell api-table-content-cell api-table-content-cell-description"><strong class="bold" >type:</strong> {{this.type}} <br/> <strong class="api-table-event-description bold">description:</strong> {{{this.description}}}</div>
|
22
|
-
{{/each}}
|
23
|
-
{{/each}}
|
24
|
-
</div>
|
25
|
-
{{/if}}`
|
26
|
-
};
|
@@ -1,40 +0,0 @@
|
|
1
|
-
module.exports = {
|
2
|
-
template: `
|
3
|
-
{{#if properties}}
|
4
|
-
<h3 class="comment-api-title" >Properties/Attributes</h3>
|
5
|
-
<p class="small-space-top" >You can use both properties and attributes with the same effect. The name of each attribute is listed below the name of the property, if different.</p>
|
6
|
-
|
7
|
-
<div class="small-space-top api-table">
|
8
|
-
<div class="head api-table-header-roll">
|
9
|
-
<div class="cell api-table-header-cell">Name</div>
|
10
|
-
<div class="cell api-table-header-cell">Type</div>
|
11
|
-
<div class="cell api-table-header-cell">Default Value</div>
|
12
|
-
<div class="cell api-table-header-cell">Description</div>
|
13
|
-
</div>
|
14
|
-
|
15
|
-
{{#each properties}}
|
16
|
-
<div class="row {{checkEven @index}}">
|
17
|
-
<div class="cell api-table-content-cell api-table-content-cell-bold">
|
18
|
-
{{this.name}}
|
19
|
-
{{#if this.readonly}}
|
20
|
-
(readonly)
|
21
|
-
{{/if}}
|
22
|
-
<br>
|
23
|
-
{{#if (toKebabCase this.name)}}
|
24
|
-
<code>{{toKebabCase this.name}}</code>
|
25
|
-
{{/if}}
|
26
|
-
</div>
|
27
|
-
<div class="cell api-table-content-cell">{{this.type}}</div>
|
28
|
-
<div class="cell api-table-content-cell">{{this.defaultValue}}</div>
|
29
|
-
<div class="cell api-table-content-cell api-table-content-cell-description">
|
30
|
-
{{{this.description}}}
|
31
|
-
{{#if this.since}}
|
32
|
-
<div class="api-table-content-cell-bold api-table-content-cell-since">since v{{{this.since}}}</div>
|
33
|
-
{{/if}}
|
34
|
-
</div>
|
35
|
-
</div>
|
36
|
-
{{/each}}
|
37
|
-
|
38
|
-
</div>
|
39
|
-
{{/if}}`
|
40
|
-
};
|
@@ -1,28 +0,0 @@
|
|
1
|
-
module.exports = {
|
2
|
-
template: `
|
3
|
-
{{#if slots}}
|
4
|
-
<h3 class="comment-api-title space-top" >Slots</h3>
|
5
|
-
<p class="small-space-top" >
|
6
|
-
This Element provides slot(s). This means it can display its child nodes.<br>
|
7
|
-
Unless targeting the default slot, use the <code>slot</code> attribute to define the destination slot for each child.<br>
|
8
|
-
Text, along with HTML Elements with no <code>slot</code> attribute, goes the the <code>default</code> slot.
|
9
|
-
</p>
|
10
|
-
|
11
|
-
<div class="small-space-top api-table">
|
12
|
-
<div class="head api-table-header-roll">
|
13
|
-
<div class="cell api-table-header-cell">Slot</div>
|
14
|
-
<div class="cell api-table-header-cell">Type</div>
|
15
|
-
<div class="cell api-table-header-cell">Description</div>
|
16
|
-
</div>
|
17
|
-
|
18
|
-
{{#each slots}}
|
19
|
-
<div class="row {{checkEven @index}}">
|
20
|
-
<div class="cell api-table-content-cell api-table-content-cell-bold">{{this.name}}</div>
|
21
|
-
<div class="cell api-table-content-cell">{{this.type}}</div>
|
22
|
-
<div class="cell api-table-content-cell api-table-content-cell-description">{{{this.description}}}</div>
|
23
|
-
</div>
|
24
|
-
{{/each}}
|
25
|
-
|
26
|
-
</div>
|
27
|
-
{{/if}}`
|
28
|
-
};
|
@@ -1,38 +0,0 @@
|
|
1
|
-
module.exports = {
|
2
|
-
template: `
|
3
|
-
<div class="page-container">
|
4
|
-
<div class="api-container">
|
5
|
-
<section class="component-description">
|
6
|
-
{{{description}}}
|
7
|
-
<section class="component-api space-top">
|
8
|
-
{{> properties this}}
|
9
|
-
{{> slots this}}
|
10
|
-
{{> events this}}
|
11
|
-
{{> methods this}}
|
12
|
-
{{> cssVariables this}}
|
13
|
-
</section>
|
14
|
-
</section>
|
15
|
-
</div>
|
16
|
-
</div>
|
17
|
-
{{#each additionalDocs}}
|
18
|
-
<div class="api-container appended-doc">
|
19
|
-
<h1>{{this.basename}}</h1>
|
20
|
-
<section class="component-description">
|
21
|
-
{{{this.description}}}
|
22
|
-
<section class="component-api space-top">
|
23
|
-
{{> properties this}}
|
24
|
-
{{> slots this}}
|
25
|
-
{{> events this}}
|
26
|
-
{{> cssVariables this}}
|
27
|
-
</section>
|
28
|
-
</section>
|
29
|
-
</div>
|
30
|
-
{{/each}}
|
31
|
-
<footer class="footer-wrapper">
|
32
|
-
<div class="footer-links">
|
33
|
-
<a class="separator" href="https://www.sap.com/about/legal/privacy.html" target="_blank">Privacy Policy</a>
|
34
|
-
<a href="https://www.sap.com/about/legal/impressum.html" target="_blank">Legal</a>
|
35
|
-
</div>
|
36
|
-
<img src="../../../../../../assets/images/sap-logo-svg.svg" alt="Sap Logo" />
|
37
|
-
</footer>`
|
38
|
-
};
|
@@ -1,119 +0,0 @@
|
|
1
|
-
const fs = require("fs");
|
2
|
-
const path = require("path");
|
3
|
-
const mkdirp = require("mkdirp");
|
4
|
-
const commandLineArgs = require('command-line-args');
|
5
|
-
const beautify = require("json-beautify");
|
6
|
-
|
7
|
-
// String utils
|
8
|
-
const kebabToCamelCase = string => toCamelCase(string.split("-"));
|
9
|
-
const toCamelCase = parts => {
|
10
|
-
return parts.map((string, index) => {
|
11
|
-
return index === 0 ? string.toLowerCase() : string.charAt(0).toUpperCase() + string.slice(1).toLowerCase();
|
12
|
-
}).join("");
|
13
|
-
};
|
14
|
-
const capitalizeFirst = str => str.substr(0,1).toUpperCase() + str.substr(1);
|
15
|
-
|
16
|
-
// content of package.json
|
17
|
-
let packageContent;
|
18
|
-
|
19
|
-
const DEFAULT_PORT = 8080;
|
20
|
-
const DEFAULT_TAG = 'ui5-demo';
|
21
|
-
const BETA_VER = "0.19.0";
|
22
|
-
const RC_VER = "1.0.0-rc.6";
|
23
|
-
|
24
|
-
// from where all the files will be copied
|
25
|
-
const RESOURCES_DIR = path.join(`${__dirname}`, `resources/`);
|
26
|
-
|
27
|
-
// Command line options
|
28
|
-
const options = commandLineArgs([
|
29
|
-
{name: 'port', alias: 'p', type: Number},
|
30
|
-
{name: 'tag', type: String},
|
31
|
-
]);
|
32
|
-
|
33
|
-
// Ensure there is package.json
|
34
|
-
try {
|
35
|
-
packageContent = JSON.parse(fs.readFileSync("package.json"));
|
36
|
-
} catch (err) {
|
37
|
-
console.log("No package.json found, please run: 'npm init' first");
|
38
|
-
process.exit(1);
|
39
|
-
}
|
40
|
-
|
41
|
-
// Ensure correct tag
|
42
|
-
const tag = options.tag || DEFAULT_TAG;
|
43
|
-
if (!tag.match(/^ui5-/)) {
|
44
|
-
console.log("tag name should start with ui5-");
|
45
|
-
process.exit(1);
|
46
|
-
}
|
47
|
-
const className = capitalizeFirst(kebabToCamelCase(tag.substr(4)));
|
48
|
-
|
49
|
-
// All variables that will be replaced in the content of the resources/
|
50
|
-
const vars = {
|
51
|
-
INIT_PACKAGE_VAR_NAME: packageContent.name,
|
52
|
-
INIT_PACKAGE_VAR_PORT: options.port || DEFAULT_PORT,
|
53
|
-
INIT_PACKAGE_VAR_TAG: tag,
|
54
|
-
INIT_PACKAGE_VAR_CLASS_NAME: className,
|
55
|
-
};
|
56
|
-
console.log(vars);
|
57
|
-
|
58
|
-
const replaceVarsInFileContent = content => {
|
59
|
-
for (let key in vars) {
|
60
|
-
const re = new RegExp(key, "g");
|
61
|
-
content = content.replace(re, vars[key]);
|
62
|
-
}
|
63
|
-
return content;
|
64
|
-
};
|
65
|
-
|
66
|
-
const replaceVarsInFileName = fileName => {
|
67
|
-
return fileName.replace(/Demo/, vars.INIT_PACKAGE_VAR_CLASS_NAME) ;
|
68
|
-
};
|
69
|
-
|
70
|
-
const copyFile = (sourcePath, destPath) => {
|
71
|
-
let content = fs.readFileSync(sourcePath, {encoding: "UTF-8"});
|
72
|
-
content = replaceVarsInFileContent(content);
|
73
|
-
destPath = replaceVarsInFileName(destPath);
|
74
|
-
fs.writeFileSync(destPath, content);
|
75
|
-
console.log(destPath);
|
76
|
-
};
|
77
|
-
|
78
|
-
const copyResources = sourcePath => {
|
79
|
-
const destPath = sourcePath.substr(RESOURCES_DIR.length);
|
80
|
-
const isDir = fs.lstatSync(sourcePath).isDirectory();
|
81
|
-
if (isDir) {
|
82
|
-
if (destPath) {
|
83
|
-
mkdirp.sync(destPath);
|
84
|
-
console.log(destPath);
|
85
|
-
}
|
86
|
-
fs.readdirSync(sourcePath).forEach(file => {
|
87
|
-
copyResources(path.join(sourcePath, file));
|
88
|
-
});
|
89
|
-
} else {
|
90
|
-
copyFile(sourcePath, destPath);
|
91
|
-
}
|
92
|
-
};
|
93
|
-
|
94
|
-
const updatePackageFile = () => {
|
95
|
-
packageContent.scripts = {
|
96
|
-
"clean": "wc-dev clean",
|
97
|
-
"lint": "wc-dev lint",
|
98
|
-
"start": "wc-dev start",
|
99
|
-
"build": "wc-dev build",
|
100
|
-
"test": "wc-dev test",
|
101
|
-
"create-ui5-element": "wc-create-ui5-element",
|
102
|
-
"prepublishOnly": "npm run build"
|
103
|
-
};
|
104
|
-
|
105
|
-
packageContent.dependencies = packageContent.dependencies || {};
|
106
|
-
packageContent.dependencies["@ui5/webcomponents-base"] = BETA_VER;
|
107
|
-
packageContent.dependencies["@ui5/webcomponents-theme-base"] = RC_VER;
|
108
|
-
packageContent.dependencies["@ui5/webcomponents-tools"] = RC_VER;
|
109
|
-
|
110
|
-
fs.writeFileSync("package.json", beautify(packageContent, null, 2, 100));
|
111
|
-
};
|
112
|
-
|
113
|
-
// Copy files
|
114
|
-
copyResources(RESOURCES_DIR);
|
115
|
-
|
116
|
-
// Update package.json
|
117
|
-
updatePackageFile();
|
118
|
-
|
119
|
-
console.log("Package successfully initialized.");
|
@@ -1,25 +0,0 @@
|
|
1
|
-
// ES5 bundle targets IE11 only
|
2
|
-
import "@ui5/webcomponents-base/dist/features/browsersupport/IE11.js";
|
3
|
-
|
4
|
-
import "./bundle.esm.js";
|
5
|
-
|
6
|
-
import { getAnimationMode } from "@ui5/webcomponents-base/dist/config/AnimationMode.js";
|
7
|
-
import { getLanguage } from "@ui5/webcomponents-base/dist/config/Language.js";
|
8
|
-
import { getCalendarType } from "@ui5/webcomponents-base/dist/config/CalendarType.js";
|
9
|
-
import { getTheme, setTheme } from "@ui5/webcomponents-base/dist/config/Theme.js";
|
10
|
-
import { getNoConflict, setNoConflict } from "@ui5/webcomponents-base/dist/config/NoConflict.js";
|
11
|
-
import { getRTL } from "@ui5/webcomponents-base/dist/config/RTL.js";
|
12
|
-
import { getFirstDayOfWeek } from "@ui5/webcomponents-base/dist/config/FormatSettings.js";
|
13
|
-
|
14
|
-
const configuration = {
|
15
|
-
getAnimationMode,
|
16
|
-
getLanguage,
|
17
|
-
getTheme,
|
18
|
-
setTheme,
|
19
|
-
getNoConflict,
|
20
|
-
setNoConflict,
|
21
|
-
getCalendarType,
|
22
|
-
getRTL,
|
23
|
-
getFirstDayOfWeek,
|
24
|
-
};
|
25
|
-
export default configuration;
|
@@ -1,34 +0,0 @@
|
|
1
|
-
// ESM bundle targets Edge + browsers with native support
|
2
|
-
import "@ui5/webcomponents-base/dist/features/browsersupport/Edge.js";
|
3
|
-
|
4
|
-
// used in test pages
|
5
|
-
import RenderScheduler from "@ui5/webcomponents-base/dist/RenderScheduler.js";
|
6
|
-
|
7
|
-
import { getAnimationMode } from "@ui5/webcomponents-base/dist/config/AnimationMode.js";
|
8
|
-
import { getLanguage } from "@ui5/webcomponents-base/dist/config/Language.js";
|
9
|
-
import { getCalendarType } from "@ui5/webcomponents-base/dist/config/CalendarType.js";
|
10
|
-
import { getTheme, setTheme } from "@ui5/webcomponents-base/dist/config/Theme.js";
|
11
|
-
import { getNoConflict, setNoConflict } from "@ui5/webcomponents-base/dist/config/NoConflict.js";
|
12
|
-
import { getRTL } from "@ui5/webcomponents-base/dist/config/RTL.js";
|
13
|
-
import { getFirstDayOfWeek } from "@ui5/webcomponents-base/dist/config/FormatSettings.js";
|
14
|
-
|
15
|
-
// Enable additional themes and i18n texts
|
16
|
-
import "./dist/Assets.js";
|
17
|
-
|
18
|
-
// Import your web components here from the dist/ directory
|
19
|
-
import "./dist/INIT_PACKAGE_VAR_CLASS_NAME.js";
|
20
|
-
|
21
|
-
window.RenderScheduler = RenderScheduler;
|
22
|
-
window["sap-ui-webcomponents-bundle"] = {
|
23
|
-
configuration: {
|
24
|
-
getAnimationMode,
|
25
|
-
getLanguage,
|
26
|
-
getTheme,
|
27
|
-
setTheme,
|
28
|
-
getNoConflict,
|
29
|
-
setNoConflict,
|
30
|
-
getCalendarType,
|
31
|
-
getRTL,
|
32
|
-
getFirstDayOfWeek,
|
33
|
-
},
|
34
|
-
};
|
@@ -1 +0,0 @@
|
|
1
|
-
module.exports = require("@ui5/webcomponents-tools/components-package/eslint.js");
|
@@ -1 +0,0 @@
|
|
1
|
-
module.exports = require("@ui5/webcomponents-tools/components-package/postcss.components.js");
|
@@ -1 +0,0 @@
|
|
1
|
-
module.exports = require("@ui5/webcomponents-tools/components-package/postcss.themes.js");
|
@@ -1 +0,0 @@
|
|
1
|
-
module.exports = require("@ui5/webcomponents-tools/components-package/rollup.js");
|
@@ -1 +0,0 @@
|
|
1
|
-
module.exports = require("@ui5/webcomponents-tools/components-package/wdio.js");
|
@@ -1 +0,0 @@
|
|
1
|
-
<div>This is: INIT_PACKAGE_VAR_TAG. {{pleaseWaitText}}</div>
|
@@ -1,56 +0,0 @@
|
|
1
|
-
import UI5Element from "@ui5/webcomponents-base/dist/UI5Element.js";
|
2
|
-
import litRender from "@ui5/webcomponents-base/dist/renderer/LitRenderer.js";
|
3
|
-
import { fetchI18nBundle, getI18nBundle } from "@ui5/webcomponents-base/dist/i18nBundle.js";
|
4
|
-
|
5
|
-
// Template
|
6
|
-
import INIT_PACKAGE_VAR_CLASS_NAMETemplate from "./generated/templates/INIT_PACKAGE_VAR_CLASS_NAMETemplate.lit.js";
|
7
|
-
|
8
|
-
// Styles
|
9
|
-
import INIT_PACKAGE_VAR_CLASS_NAMECss from "./generated/themes/INIT_PACKAGE_VAR_CLASS_NAME.css.js";
|
10
|
-
|
11
|
-
import { PLEASE_WAIT } from "./generated/i18n/i18n-defaults.js";
|
12
|
-
|
13
|
-
const metadata = {
|
14
|
-
tag: "INIT_PACKAGE_VAR_TAG",
|
15
|
-
properties: {
|
16
|
-
},
|
17
|
-
slots: {
|
18
|
-
},
|
19
|
-
events: {
|
20
|
-
},
|
21
|
-
};
|
22
|
-
|
23
|
-
class INIT_PACKAGE_VAR_CLASS_NAME extends UI5Element {
|
24
|
-
constructor() {
|
25
|
-
super();
|
26
|
-
this.i18nBundle = getI18nBundle("INIT_PACKAGE_VAR_NAME");
|
27
|
-
}
|
28
|
-
|
29
|
-
get pleaseWaitText() {
|
30
|
-
return this.i18nBundle.getText(PLEASE_WAIT);
|
31
|
-
}
|
32
|
-
|
33
|
-
static get metadata() {
|
34
|
-
return metadata;
|
35
|
-
}
|
36
|
-
|
37
|
-
static get render() {
|
38
|
-
return litRender;
|
39
|
-
}
|
40
|
-
|
41
|
-
static get template() {
|
42
|
-
return INIT_PACKAGE_VAR_CLASS_NAMETemplate;
|
43
|
-
}
|
44
|
-
|
45
|
-
static get styles() {
|
46
|
-
return INIT_PACKAGE_VAR_CLASS_NAMECss;
|
47
|
-
}
|
48
|
-
|
49
|
-
static async onDefine() {
|
50
|
-
await fetchI18nBundle("INIT_PACKAGE_VAR_NAME");
|
51
|
-
}
|
52
|
-
}
|
53
|
-
|
54
|
-
INIT_PACKAGE_VAR_CLASS_NAME.define();
|
55
|
-
|
56
|
-
export default INIT_PACKAGE_VAR_CLASS_NAME;
|
@@ -1 +0,0 @@
|
|
1
|
-
PLEASE_WAIT=Bitte warten
|
@@ -1 +0,0 @@
|
|
1
|
-
PLEASE_WAIT=Please wait
|
@@ -1 +0,0 @@
|
|
1
|
-
PLEASE_WAIT=Espere
|
@@ -1 +0,0 @@
|
|
1
|
-
PLEASE_WAIT=Patientez.
|
@@ -1,11 +0,0 @@
|
|
1
|
-
:host {
|
2
|
-
border: 2px solid var(--ui5-demo-border-color);
|
3
|
-
background-color: var(--sapBackgroundColor);
|
4
|
-
color: var(--sapTextColor);
|
5
|
-
display: block;
|
6
|
-
width: 16rem;
|
7
|
-
height: 3rem;
|
8
|
-
text-align: center;
|
9
|
-
vertical-align: middle;
|
10
|
-
line-height: 3rem;
|
11
|
-
}
|
@@ -1,51 +0,0 @@
|
|
1
|
-
<!DOCTYPE html>
|
2
|
-
<html>
|
3
|
-
|
4
|
-
<head>
|
5
|
-
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
6
|
-
<meta charset="utf-8">
|
7
|
-
|
8
|
-
<title>INIT_PACKAGE_VAR_TAG</title>
|
9
|
-
<meta name="viewport" content="width=device-width, initial-scale=1">
|
10
|
-
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
11
|
-
<meta charset="utf-8">
|
12
|
-
|
13
|
-
<script data-ui5-config type="application/json">
|
14
|
-
{
|
15
|
-
"language": "EN"
|
16
|
-
}
|
17
|
-
</script>
|
18
|
-
|
19
|
-
<script src="../../webcomponentsjs/webcomponents-loader.js"></script>
|
20
|
-
<script src="../../resources/bundle.esm.js" type="module"></script>
|
21
|
-
<script nomodule src="../../resources/bundle.es5.js"></script>
|
22
|
-
|
23
|
-
<style>
|
24
|
-
code { color: blue; font-size: small; }
|
25
|
-
</style>
|
26
|
-
|
27
|
-
</head>
|
28
|
-
|
29
|
-
<body>
|
30
|
-
<a href="?sap-ui-theme=sap_fiori_3">Fiori 3</a> |
|
31
|
-
<a href="?sap-ui-theme=sap_fiori_3_dark">Fiori 3 Dark</a> |
|
32
|
-
<a href="?sap-ui-theme=sap_belize">Belize</a> |
|
33
|
-
<a href="?sap-ui-theme=sap_belize_hcb">Belize High Contrast Black</a>
|
34
|
-
<br>
|
35
|
-
<span>or in the browser console, for example:</span>
|
36
|
-
<code>window['sap-ui-webcomponents-bundle'].configuration.setTheme("sap_belize_hcb")</code>
|
37
|
-
|
38
|
-
<br><br>
|
39
|
-
|
40
|
-
<a href="?sap-ui-language=en">English</a> |
|
41
|
-
<a href="?sap-ui-language=de">German</a> |
|
42
|
-
<a href="?sap-ui-language=es">Spanish</a> |
|
43
|
-
<a href="?sap-ui-language=fr">French</a>
|
44
|
-
|
45
|
-
<br><br>
|
46
|
-
|
47
|
-
<h1>Test your web components here</h1>
|
48
|
-
<INIT_PACKAGE_VAR_TAG id="myFirstComponent"></INIT_PACKAGE_VAR_TAG>
|
49
|
-
</body>
|
50
|
-
|
51
|
-
</html>
|
@@ -1,12 +0,0 @@
|
|
1
|
-
const assert = require("assert");
|
2
|
-
|
3
|
-
describe("INIT_PACKAGE_VAR_TAG rendering", () => {
|
4
|
-
browser.url("http://localhost:INIT_PACKAGE_VAR_PORT/test-resources/pages/index.html");
|
5
|
-
|
6
|
-
it("tests if web component is correctly rendered", () => {
|
7
|
-
|
8
|
-
const innerContent = browser.$("#myFirstComponent").shadow$("div");
|
9
|
-
|
10
|
-
assert.ok(innerContent, "content rendered");
|
11
|
-
});
|
12
|
-
});
|
@@ -1,42 +0,0 @@
|
|
1
|
-
const postcss = require('postcss');
|
2
|
-
const fs = require('fs');
|
3
|
-
const path = require('path');
|
4
|
-
const mkdirp = require('mkdirp');
|
5
|
-
const assets = require("../../assets-meta.js");
|
6
|
-
|
7
|
-
const DEFAULT_THEME = assets.themes.default;
|
8
|
-
|
9
|
-
const getDefaultThemeCode = packageName => {
|
10
|
-
return `import { registerThemeProperties } from "@ui5/webcomponents-base/dist/asset-registries/Themes.js";
|
11
|
-
|
12
|
-
import defaultThemeBase from "@ui5/webcomponents-theme-base/dist/generated/themes/${DEFAULT_THEME}/parameters-bundle.css.js";
|
13
|
-
import defaultTheme from "./${DEFAULT_THEME}/parameters-bundle.css.js";
|
14
|
-
|
15
|
-
registerThemeProperties("@ui5/webcomponents-theme-base", "${DEFAULT_THEME}", defaultThemeBase);
|
16
|
-
registerThemeProperties("${packageName}", "${DEFAULT_THEME}", defaultTheme);
|
17
|
-
`;
|
18
|
-
};
|
19
|
-
|
20
|
-
const proccessCSS = css => {
|
21
|
-
css = css.replace(/\.sapThemeMeta[\s\S]*?:root/, ":root");
|
22
|
-
css = css.replace(/\.background-image.*{.*}/, "");
|
23
|
-
css = css.replace(/\.sapContrast[ ]*:root[\s\S]*?}/, "");
|
24
|
-
css = css.replace(/--sapFontUrl.*\);?/, "");
|
25
|
-
return JSON.stringify(css);
|
26
|
-
}
|
27
|
-
|
28
|
-
module.exports = postcss.plugin('add css to esm transform plugin', function (opts) {
|
29
|
-
opts = opts || {};
|
30
|
-
|
31
|
-
return function (root) {
|
32
|
-
let css = root.toString();
|
33
|
-
css = proccessCSS(css);
|
34
|
-
|
35
|
-
const targetFile = root.source.input.from.replace(`/${opts.toReplace}/`, "/dist/generated/").replace(`\\${opts.toReplace}\\`, "\\dist\\generated\\");
|
36
|
-
mkdirp.sync(path.dirname(targetFile));
|
37
|
-
|
38
|
-
const filePath = `${targetFile}.js`;
|
39
|
-
const defaultTheme = opts.includeDefaultTheme ? getDefaultThemeCode(opts.packageName) : ``;
|
40
|
-
fs.writeFileSync(filePath, `${defaultTheme}export default ${css};`);
|
41
|
-
}
|
42
|
-
});
|
@@ -1,27 +0,0 @@
|
|
1
|
-
const postcss = require('postcss');
|
2
|
-
const fs = require('fs');
|
3
|
-
const path = require('path');
|
4
|
-
const mkdirp = require('mkdirp');
|
5
|
-
|
6
|
-
const proccessCSS = css => {
|
7
|
-
css = css.replace(/\.sapThemeMeta[\s\S]*?:root/, ":root");
|
8
|
-
css = css.replace(/\.background-image.*{.*}/, "");
|
9
|
-
css = css.replace(/\.sapContrast[ ]*:root[\s\S]*?}/, "");
|
10
|
-
css = css.replace(/--sapFontUrl.*\);?/, "");
|
11
|
-
return css;
|
12
|
-
}
|
13
|
-
|
14
|
-
module.exports = postcss.plugin('add css to JSON transform plugin', function (opts) {
|
15
|
-
opts = opts || {};
|
16
|
-
|
17
|
-
return function (root) {
|
18
|
-
let css = root.toString();
|
19
|
-
css = proccessCSS(css);
|
20
|
-
|
21
|
-
const targetFile = root.source.input.from.replace(`/${opts.toReplace}/`, "/dist/generated/assets/").replace(`\\${opts.toReplace}\\`, "\\dist\\generated\\assets\\");
|
22
|
-
mkdirp.sync(path.dirname(targetFile));
|
23
|
-
|
24
|
-
const filePath = `${targetFile}.json`;
|
25
|
-
fs.writeFileSync(filePath, JSON.stringify({_: css}));
|
26
|
-
}
|
27
|
-
});
|