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/lint/eslint/eslint-plugin-mozilla/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/ | ||||
| 
 | ||||
| # 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/viaduct/fetch_msg_types.pb.cc | ||||
| toolkit/components/viaduct/fetch_msg_types.pb.h | ||||
| toolkit/content/widgets/vendor/lit.all.mjs | ||||
| toolkit/crashreporter/breakpad-client/ | ||||
| toolkit/crashreporter/google-breakpad/ | ||||
| tools/fuzzing/libfuzzer/ | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Mark Striemer
						Mark Striemer