forked from mirrors/gecko-dev
Bug 1798911 - Setup lit for development of toolkit widgets r=hjones
Differential Revision: https://phabricator.services.mozilla.com/D161141
This commit is contained in:
parent
8564e9f846
commit
6064b195e4
10 changed files with 420 additions and 0 deletions
|
|
@ -169,6 +169,9 @@ _OPT\.OBJ/
|
||||||
^tools/browsertime/node_modules/
|
^tools/browsertime/node_modules/
|
||||||
^tools/lint/eslint/eslint-plugin-mozilla/node_modules/
|
^tools/lint/eslint/eslint-plugin-mozilla/node_modules/
|
||||||
^browser/components/newtab/node_modules/
|
^browser/components/newtab/node_modules/
|
||||||
|
^toolkit/content/vendor/lit/node_modules/
|
||||||
|
# Bug 1790483 Ignore lit - development only for now.
|
||||||
|
^toolkit/content/widgets/vendor/lit.all.mjs
|
||||||
^tools/esmify/node_modules/
|
^tools/esmify/node_modules/
|
||||||
|
|
||||||
# Ignore talos virtualenv and tp5n files.
|
# Ignore talos virtualenv and tp5n files.
|
||||||
|
|
|
||||||
28
toolkit/content/vendor/lit/LICENSE
vendored
Normal file
28
toolkit/content/vendor/lit/LICENSE
vendored
Normal file
|
|
@ -0,0 +1,28 @@
|
||||||
|
BSD 3-Clause License
|
||||||
|
|
||||||
|
Copyright (c) 2017 Google LLC. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1. Redistributions of source code must retain the above copyright notice, this
|
||||||
|
list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer in the documentation
|
||||||
|
and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3. Neither the name of the copyright holder nor the names of its
|
||||||
|
contributors may be used to endorse or promote products derived from
|
||||||
|
this software without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
||||||
|
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||||
|
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||||||
|
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||||
|
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
31
toolkit/content/vendor/lit/README.md
vendored
Normal file
31
toolkit/content/vendor/lit/README.md
vendored
Normal file
|
|
@ -0,0 +1,31 @@
|
||||||
|
# Vendoring for lit
|
||||||
|
|
||||||
|
[lit](https://lit.dev/) can be used to help create Web Components.
|
||||||
|
|
||||||
|
## The lit.all.mjs bundle
|
||||||
|
|
||||||
|
The lit package is imported in a vendoring step and the contents are extracted
|
||||||
|
into the lit.all.mjs file. This has some differences from using lit in a regular
|
||||||
|
npm project. Imports that would normally be into a specific file are pulled
|
||||||
|
directly from the lit.all.mjs file.
|
||||||
|
|
||||||
|
eg.
|
||||||
|
|
||||||
|
```
|
||||||
|
// Standard npm package:
|
||||||
|
import { LitElement } from "lit";
|
||||||
|
import { classMap } from "lit/directives/class-map.js";
|
||||||
|
|
||||||
|
// Using lit.all.mjs (pathing to lit.all.mjs may differ)
|
||||||
|
import { classMap, LitElement } from "../vendor/lit.all.mjs";
|
||||||
|
|
||||||
|
## To update the lit bundle
|
||||||
|
|
||||||
|
Using `mach`s `npm` you can update the bundle with:
|
||||||
|
|
||||||
|
```
|
||||||
|
cd toolkit/content/vendor/lit
|
||||||
|
../../../../mach npm run vendor
|
||||||
|
```
|
||||||
|
|
||||||
|
Then commit the changes.
|
||||||
20
toolkit/content/vendor/lit/index.mjs
vendored
Normal file
20
toolkit/content/vendor/lit/index.mjs
vendored
Normal file
|
|
@ -0,0 +1,20 @@
|
||||||
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
||||||
|
* You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
/* eslint-disable import/no-unassigned-import */
|
||||||
|
/* eslint-disable import/no-unresolved */
|
||||||
|
|
||||||
|
export * from "lit";
|
||||||
|
export * from "lit/directives/async-append.js";
|
||||||
|
export * from "lit/directives/async-replace.js";
|
||||||
|
export * from "lit/directives/cache.js";
|
||||||
|
export * from "lit/directives/class-map.js";
|
||||||
|
export * from "lit/directives/guard.js";
|
||||||
|
export * from "lit/directives/if-defined.js";
|
||||||
|
export * from "lit/directives/live.js";
|
||||||
|
export * from "lit/directives/ref.js";
|
||||||
|
export * from "lit/directives/repeat.js";
|
||||||
|
export * from "lit/directives/style-map.js";
|
||||||
|
export * from "lit/directives/template-content.js";
|
||||||
|
export * from "lit/directives/until.js";
|
||||||
|
export * from "lit/decorators.js";
|
||||||
17
toolkit/content/vendor/lit/lit-html-no-inner-html.patch
vendored
Normal file
17
toolkit/content/vendor/lit/lit-html-no-inner-html.patch
vendored
Normal file
|
|
@ -0,0 +1,17 @@
|
||||||
|
--- lit.all.mjs
|
||||||
|
+++ lit.all.mjs.patched
|
||||||
|
@@ -358,8 +358,12 @@
|
||||||
|
}
|
||||||
|
}
|
||||||
|
static createElement(t7, i9) {
|
||||||
|
- const s8 = h2.createElement("template");
|
||||||
|
- return s8.innerHTML = t7, s8;
|
||||||
|
+ const parser = new DOMParser();
|
||||||
|
+ const doc = parser.parseFromString(
|
||||||
|
+ `<template>${t7}</template>`,
|
||||||
|
+ "text/html"
|
||||||
|
+ );
|
||||||
|
+ return document.importNode(doc.querySelector("template"), true);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
function P(t7, i9, s8 = t7, e14) {
|
||||||
14
toolkit/content/vendor/lit/moz.yaml
vendored
Normal file
14
toolkit/content/vendor/lit/moz.yaml
vendored
Normal file
|
|
@ -0,0 +1,14 @@
|
||||||
|
schema: 1
|
||||||
|
|
||||||
|
bugzilla:
|
||||||
|
product: "Toolkit"
|
||||||
|
component: "XUL Widgets"
|
||||||
|
|
||||||
|
origin:
|
||||||
|
name: "lit"
|
||||||
|
description:
|
||||||
|
"Lit is a simple library for building fast, lightweight web components."
|
||||||
|
url: "https://github.com/lit/lit"
|
||||||
|
license: "BSD-3-Clause"
|
||||||
|
release: "2.4.0"
|
||||||
|
revision: "lit@2.4.0"
|
||||||
185
toolkit/content/vendor/lit/package-lock.json
generated
vendored
Normal file
185
toolkit/content/vendor/lit/package-lock.json
generated
vendored
Normal file
|
|
@ -0,0 +1,185 @@
|
||||||
|
{
|
||||||
|
"name": "vendor-lit",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"lockfileVersion": 2,
|
||||||
|
"requires": true,
|
||||||
|
"packages": {
|
||||||
|
"": {
|
||||||
|
"name": "vendor-lit",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"license": "MPL-2.0",
|
||||||
|
"dependencies": {
|
||||||
|
"lit": "^2.4.0"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"esbuild": "^0.15.10"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/@lit/reactive-element": {
|
||||||
|
"version": "1.4.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/@lit/reactive-element/-/reactive-element-1.4.1.tgz",
|
||||||
|
"integrity": "sha512-qDv4851VFSaBWzpS02cXHclo40jsbAjRXnebNXpm0uVg32kCneZPo9RYVQtrTNICtZ+1wAYHu1ZtxWSWMbKrBw=="
|
||||||
|
},
|
||||||
|
"node_modules/@types/trusted-types": {
|
||||||
|
"version": "2.0.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/@types/trusted-types/-/trusted-types-2.0.2.tgz",
|
||||||
|
"integrity": "sha512-F5DIZ36YVLE+PN+Zwws4kJogq47hNgX3Nx6WyDJ3kcplxyke3XIzB8uK5n/Lpm1HBsbGzd6nmGehL8cPekP+Tg=="
|
||||||
|
},
|
||||||
|
"node_modules/esbuild": {
|
||||||
|
"version": "0.15.10",
|
||||||
|
"resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.15.10.tgz",
|
||||||
|
"integrity": "sha512-N7wBhfJ/E5fzn/SpNgX+oW2RLRjwaL8Y0ezqNqhjD6w0H2p0rDuEz2FKZqpqLnO8DCaWumKe8dsC/ljvVSSxng==",
|
||||||
|
"dev": true,
|
||||||
|
"hasInstallScript": true,
|
||||||
|
"bin": {
|
||||||
|
"esbuild": "bin/esbuild"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">=12"
|
||||||
|
},
|
||||||
|
"optionalDependencies": {
|
||||||
|
"@esbuild/android-arm": "0.15.10",
|
||||||
|
"@esbuild/linux-loong64": "0.15.10",
|
||||||
|
"esbuild-android-64": "0.15.10",
|
||||||
|
"esbuild-android-arm64": "0.15.10",
|
||||||
|
"esbuild-darwin-64": "0.15.10",
|
||||||
|
"esbuild-darwin-arm64": "0.15.10",
|
||||||
|
"esbuild-freebsd-64": "0.15.10",
|
||||||
|
"esbuild-freebsd-arm64": "0.15.10",
|
||||||
|
"esbuild-linux-32": "0.15.10",
|
||||||
|
"esbuild-linux-64": "0.15.10",
|
||||||
|
"esbuild-linux-arm": "0.15.10",
|
||||||
|
"esbuild-linux-arm64": "0.15.10",
|
||||||
|
"esbuild-linux-mips64le": "0.15.10",
|
||||||
|
"esbuild-linux-ppc64le": "0.15.10",
|
||||||
|
"esbuild-linux-riscv64": "0.15.10",
|
||||||
|
"esbuild-linux-s390x": "0.15.10",
|
||||||
|
"esbuild-netbsd-64": "0.15.10",
|
||||||
|
"esbuild-openbsd-64": "0.15.10",
|
||||||
|
"esbuild-sunos-64": "0.15.10",
|
||||||
|
"esbuild-windows-32": "0.15.10",
|
||||||
|
"esbuild-windows-64": "0.15.10",
|
||||||
|
"esbuild-windows-arm64": "0.15.10"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/esbuild-windows-64": {
|
||||||
|
"version": "0.15.10",
|
||||||
|
"resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.15.10.tgz",
|
||||||
|
"integrity": "sha512-2H0gdsyHi5x+8lbng3hLbxDWR7mKHWh5BXZGKVG830KUmXOOWFE2YKJ4tHRkejRduOGDrBvHBriYsGtmTv3ntA==",
|
||||||
|
"cpu": [
|
||||||
|
"x64"
|
||||||
|
],
|
||||||
|
"dev": true,
|
||||||
|
"optional": true,
|
||||||
|
"os": [
|
||||||
|
"win32"
|
||||||
|
],
|
||||||
|
"engines": {
|
||||||
|
"node": ">=12"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/lit": {
|
||||||
|
"version": "2.4.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/lit/-/lit-2.4.0.tgz",
|
||||||
|
"integrity": "sha512-fdgzxEtLrZFQU/BqTtxFQCLwlZd9bdat+ltzSFjvWkZrs7eBmeX0L5MHUMb3kYIkuS8Xlfnii/iI5klirF8/Xg==",
|
||||||
|
"dependencies": {
|
||||||
|
"@lit/reactive-element": "^1.4.0",
|
||||||
|
"lit-element": "^3.2.0",
|
||||||
|
"lit-html": "^2.4.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/lit-element": {
|
||||||
|
"version": "3.2.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/lit-element/-/lit-element-3.2.2.tgz",
|
||||||
|
"integrity": "sha512-6ZgxBR9KNroqKb6+htkyBwD90XGRiqKDHVrW/Eh0EZ+l+iC+u+v+w3/BA5NGi4nizAVHGYvQBHUDuSmLjPp7NQ==",
|
||||||
|
"dependencies": {
|
||||||
|
"@lit/reactive-element": "^1.3.0",
|
||||||
|
"lit-html": "^2.2.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/lit-html": {
|
||||||
|
"version": "2.4.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/lit-html/-/lit-html-2.4.0.tgz",
|
||||||
|
"integrity": "sha512-G6qXu4JNUpY6aaF2VMfaszhO9hlWw0hOTRFDmuMheg/nDYGB+2RztUSOyrzALAbr8Nh0Y7qjhYkReh3rPnplVg==",
|
||||||
|
"dependencies": {
|
||||||
|
"@types/trusted-types": "^2.0.2"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"@lit/reactive-element": {
|
||||||
|
"version": "1.4.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/@lit/reactive-element/-/reactive-element-1.4.1.tgz",
|
||||||
|
"integrity": "sha512-qDv4851VFSaBWzpS02cXHclo40jsbAjRXnebNXpm0uVg32kCneZPo9RYVQtrTNICtZ+1wAYHu1ZtxWSWMbKrBw=="
|
||||||
|
},
|
||||||
|
"@types/trusted-types": {
|
||||||
|
"version": "2.0.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/@types/trusted-types/-/trusted-types-2.0.2.tgz",
|
||||||
|
"integrity": "sha512-F5DIZ36YVLE+PN+Zwws4kJogq47hNgX3Nx6WyDJ3kcplxyke3XIzB8uK5n/Lpm1HBsbGzd6nmGehL8cPekP+Tg=="
|
||||||
|
},
|
||||||
|
"esbuild": {
|
||||||
|
"version": "0.15.10",
|
||||||
|
"resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.15.10.tgz",
|
||||||
|
"integrity": "sha512-N7wBhfJ/E5fzn/SpNgX+oW2RLRjwaL8Y0ezqNqhjD6w0H2p0rDuEz2FKZqpqLnO8DCaWumKe8dsC/ljvVSSxng==",
|
||||||
|
"dev": true,
|
||||||
|
"requires": {
|
||||||
|
"@esbuild/android-arm": "0.15.10",
|
||||||
|
"@esbuild/linux-loong64": "0.15.10",
|
||||||
|
"esbuild-android-64": "0.15.10",
|
||||||
|
"esbuild-android-arm64": "0.15.10",
|
||||||
|
"esbuild-darwin-64": "0.15.10",
|
||||||
|
"esbuild-darwin-arm64": "0.15.10",
|
||||||
|
"esbuild-freebsd-64": "0.15.10",
|
||||||
|
"esbuild-freebsd-arm64": "0.15.10",
|
||||||
|
"esbuild-linux-32": "0.15.10",
|
||||||
|
"esbuild-linux-64": "0.15.10",
|
||||||
|
"esbuild-linux-arm": "0.15.10",
|
||||||
|
"esbuild-linux-arm64": "0.15.10",
|
||||||
|
"esbuild-linux-mips64le": "0.15.10",
|
||||||
|
"esbuild-linux-ppc64le": "0.15.10",
|
||||||
|
"esbuild-linux-riscv64": "0.15.10",
|
||||||
|
"esbuild-linux-s390x": "0.15.10",
|
||||||
|
"esbuild-netbsd-64": "0.15.10",
|
||||||
|
"esbuild-openbsd-64": "0.15.10",
|
||||||
|
"esbuild-sunos-64": "0.15.10",
|
||||||
|
"esbuild-windows-32": "0.15.10",
|
||||||
|
"esbuild-windows-64": "0.15.10",
|
||||||
|
"esbuild-windows-arm64": "0.15.10"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"esbuild-windows-64": {
|
||||||
|
"version": "0.15.10",
|
||||||
|
"resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.15.10.tgz",
|
||||||
|
"integrity": "sha512-2H0gdsyHi5x+8lbng3hLbxDWR7mKHWh5BXZGKVG830KUmXOOWFE2YKJ4tHRkejRduOGDrBvHBriYsGtmTv3ntA==",
|
||||||
|
"dev": true,
|
||||||
|
"optional": true
|
||||||
|
},
|
||||||
|
"lit": {
|
||||||
|
"version": "2.4.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/lit/-/lit-2.4.0.tgz",
|
||||||
|
"integrity": "sha512-fdgzxEtLrZFQU/BqTtxFQCLwlZd9bdat+ltzSFjvWkZrs7eBmeX0L5MHUMb3kYIkuS8Xlfnii/iI5klirF8/Xg==",
|
||||||
|
"requires": {
|
||||||
|
"@lit/reactive-element": "^1.4.0",
|
||||||
|
"lit-element": "^3.2.0",
|
||||||
|
"lit-html": "^2.4.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"lit-element": {
|
||||||
|
"version": "3.2.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/lit-element/-/lit-element-3.2.2.tgz",
|
||||||
|
"integrity": "sha512-6ZgxBR9KNroqKb6+htkyBwD90XGRiqKDHVrW/Eh0EZ+l+iC+u+v+w3/BA5NGi4nizAVHGYvQBHUDuSmLjPp7NQ==",
|
||||||
|
"requires": {
|
||||||
|
"@lit/reactive-element": "^1.3.0",
|
||||||
|
"lit-html": "^2.2.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"lit-html": {
|
||||||
|
"version": "2.4.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/lit-html/-/lit-html-2.4.0.tgz",
|
||||||
|
"integrity": "sha512-G6qXu4JNUpY6aaF2VMfaszhO9hlWw0hOTRFDmuMheg/nDYGB+2RztUSOyrzALAbr8Nh0Y7qjhYkReh3rPnplVg==",
|
||||||
|
"requires": {
|
||||||
|
"@types/trusted-types": "^2.0.2"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
21
toolkit/content/vendor/lit/package.json
vendored
Normal file
21
toolkit/content/vendor/lit/package.json
vendored
Normal file
|
|
@ -0,0 +1,21 @@
|
||||||
|
{
|
||||||
|
"name": "vendor-lit",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"description": "Vendor the lit package",
|
||||||
|
"main": "index.mjs",
|
||||||
|
"scripts": {
|
||||||
|
"build": "esbuild index.mjs --bundle --outfile=lit.all.mjs --format=esm --legal-comments=inline",
|
||||||
|
"patch": "patch lit.all.mjs lit-html-no-inner-html.patch",
|
||||||
|
"mv-dest": "mkdir -p ../../widgets/vendor && mv lit.all.mjs ../../widgets/vendor/lit.all.mjs",
|
||||||
|
"vendor": "npm install && npm run build && npm run patch && npm run mv-dest",
|
||||||
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||||||
|
},
|
||||||
|
"author": "",
|
||||||
|
"license": "MPL-2.0",
|
||||||
|
"dependencies": {
|
||||||
|
"lit": "^2.4.0"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"esbuild": "^0.15.10"
|
||||||
|
}
|
||||||
|
}
|
||||||
100
toolkit/content/widgets/lit-utils.mjs
Normal file
100
toolkit/content/widgets/lit-utils.mjs
Normal file
|
|
@ -0,0 +1,100 @@
|
||||||
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
||||||
|
* You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
|
// Bug 1790483: Lit is not bundled yet, this is dev only.
|
||||||
|
// eslint-disable-next-line import/no-unresolved
|
||||||
|
import { query, queryAll, LitElement } from "./vendor/lit.all.mjs";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MozLitElement provides extensions to the lit-provided LitElement class.
|
||||||
|
*
|
||||||
|
*******
|
||||||
|
*
|
||||||
|
* `@query` support (define a getter for a querySelector):
|
||||||
|
*
|
||||||
|
* static get queries() {
|
||||||
|
* return {
|
||||||
|
* propertyName: ".aNormal .cssSelector",
|
||||||
|
* anotherName: { all: ".selectorFor .querySelectorAll" },
|
||||||
|
* };
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* This example would add properties that would be written like this without
|
||||||
|
* using `queries`:
|
||||||
|
*
|
||||||
|
* get propertyName() {
|
||||||
|
* return this.renderRoot?.querySelector(".aNormal .cssSelector");
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* get anotherName() {
|
||||||
|
* return this.renderRoot?.querySelectorAll(".selectorFor .querySelectorAll");
|
||||||
|
* }
|
||||||
|
*******
|
||||||
|
*
|
||||||
|
* Automatic Fluent support for shadow DOM.
|
||||||
|
*
|
||||||
|
* Fluent requires that a shadowRoot be connected before it can use Fluent.
|
||||||
|
* Shadow roots will get connected automatically.
|
||||||
|
*
|
||||||
|
*******
|
||||||
|
*
|
||||||
|
* Test helper for sending events after a change: `dispatchOnUpdateComplete`
|
||||||
|
*
|
||||||
|
* When some async stuff is going on and you want to wait for it in a test, you
|
||||||
|
* can use `this.dispatchOnUpdateComplete(myEvent)` and have the test wait on
|
||||||
|
* your event.
|
||||||
|
*
|
||||||
|
* The component will then wait for your reactive property change to take effect
|
||||||
|
* and dispatch the desired event.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* async onClick() {
|
||||||
|
* let response = await this.getServerResponse(this.data);
|
||||||
|
* // Show the response status to the user.
|
||||||
|
* this.responseStatus = respose.status;
|
||||||
|
* this.dispatchOnUpdateComplete(
|
||||||
|
* new CustomEvent("status-shown")
|
||||||
|
* );
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* add_task(async testButton() {
|
||||||
|
* let button = this.setupAndGetButton();
|
||||||
|
* button.click();
|
||||||
|
* await BrowserTestUtils.waitForEvent(button, "status-shown");
|
||||||
|
* });
|
||||||
|
*/
|
||||||
|
export class MozLitElement extends LitElement {
|
||||||
|
constructor() {
|
||||||
|
super();
|
||||||
|
let { queries } = this.constructor;
|
||||||
|
if (queries) {
|
||||||
|
for (let [name, selector] of Object.entries(queries)) {
|
||||||
|
if (selector.all) {
|
||||||
|
queryAll(selector.all)(this, name);
|
||||||
|
} else {
|
||||||
|
query(selector)(this, name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
connectedCallback() {
|
||||||
|
super.connectedCallback();
|
||||||
|
if (!this._l10nRootConnected && document.l10n) {
|
||||||
|
document.l10n.connectRoot(this.renderRoot);
|
||||||
|
this._l10nRootConnected = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async dispatchOnUpdateComplete(event) {
|
||||||
|
await this.updateComplete;
|
||||||
|
this.dispatchEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
update() {
|
||||||
|
super.update();
|
||||||
|
document.l10n.translateFragment(this.renderRoot);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -176,6 +176,7 @@ toolkit/components/url-classifier/chromium/
|
||||||
toolkit/components/utils/mozjexl.js
|
toolkit/components/utils/mozjexl.js
|
||||||
toolkit/components/viaduct/fetch_msg_types.pb.cc
|
toolkit/components/viaduct/fetch_msg_types.pb.cc
|
||||||
toolkit/components/viaduct/fetch_msg_types.pb.h
|
toolkit/components/viaduct/fetch_msg_types.pb.h
|
||||||
|
toolkit/content/widgets/vendor/lit.all.mjs
|
||||||
toolkit/crashreporter/breakpad-client/
|
toolkit/crashreporter/breakpad-client/
|
||||||
toolkit/crashreporter/google-breakpad/
|
toolkit/crashreporter/google-breakpad/
|
||||||
tools/fuzzing/libfuzzer/
|
tools/fuzzing/libfuzzer/
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue