mirror of
				https://github.com/home-assistant/frontend.git
				synced 2025-10-31 14:39:38 +00:00 
			
		
		
		
	 21b3177f95
			
		
	
	21b3177f95
	
	
	
		
			
			* replace paper item in sidebar * make items same height as before * remove polymer refs * fix user badge * replace removed styles (and remove unused)
		
			
				
	
	
		
			215 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			215 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // Gulp task to gather all static files.
 | |
| 
 | |
| import fs from "fs-extra";
 | |
| import gulp from "gulp";
 | |
| import path from "path";
 | |
| import paths from "../paths.cjs";
 | |
| 
 | |
| const npmPath = (...parts) =>
 | |
|   path.resolve(paths.root_dir, "node_modules", ...parts);
 | |
| const polyPath = (...parts) => path.resolve(paths.root_dir, ...parts);
 | |
| 
 | |
| const copyFileDir = (fromFile, toDir) =>
 | |
|   fs.copySync(fromFile, path.join(toDir, path.basename(fromFile)));
 | |
| 
 | |
| const genStaticPath =
 | |
|   (staticDir) =>
 | |
|   (...parts) =>
 | |
|     path.resolve(staticDir, ...parts);
 | |
| 
 | |
| function copyTranslations(staticDir) {
 | |
|   const staticPath = genStaticPath(staticDir);
 | |
| 
 | |
|   // Translation output
 | |
|   fs.copySync(
 | |
|     polyPath("build/translations/output"),
 | |
|     staticPath("translations")
 | |
|   );
 | |
| }
 | |
| 
 | |
| function copyLocaleData(staticDir) {
 | |
|   const staticPath = genStaticPath(staticDir);
 | |
| 
 | |
|   // Locale data output
 | |
|   fs.copySync(polyPath("build/locale-data"), staticPath("locale-data"));
 | |
| }
 | |
| 
 | |
| function copyMdiIcons(staticDir) {
 | |
|   const staticPath = genStaticPath(staticDir);
 | |
| 
 | |
|   // MDI icons output
 | |
|   fs.copySync(polyPath("build/mdi"), staticPath("mdi"));
 | |
| }
 | |
| 
 | |
| function copyPolyfills(staticDir) {
 | |
|   const staticPath = genStaticPath(staticDir);
 | |
| 
 | |
|   // For custom panels using ES5 builds that don't use Babel 7+
 | |
|   copyFileDir(
 | |
|     npmPath("@webcomponents/webcomponentsjs/custom-elements-es5-adapter.js"),
 | |
|     staticPath("polyfills/")
 | |
|   );
 | |
| 
 | |
|   // Web Component polyfills and adapters
 | |
|   copyFileDir(
 | |
|     npmPath("@webcomponents/webcomponentsjs/webcomponents-bundle.js"),
 | |
|     staticPath("polyfills/")
 | |
|   );
 | |
|   copyFileDir(
 | |
|     npmPath("@webcomponents/webcomponentsjs/webcomponents-bundle.js.map"),
 | |
|     staticPath("polyfills/")
 | |
|   );
 | |
|   // Lit polyfill support
 | |
|   fs.copySync(
 | |
|     npmPath("lit/polyfill-support.js"),
 | |
|     path.join(staticPath("polyfills/"), "lit-polyfill-support.js")
 | |
|   );
 | |
| 
 | |
|   // dialog-polyfill css
 | |
|   copyFileDir(
 | |
|     npmPath("dialog-polyfill/dialog-polyfill.css"),
 | |
|     staticPath("polyfills/")
 | |
|   );
 | |
| }
 | |
| 
 | |
| function copyFonts(staticDir) {
 | |
|   const staticPath = genStaticPath(staticDir);
 | |
|   // Local fonts
 | |
|   fs.copySync(
 | |
|     npmPath("roboto-fontface/fonts/roboto/"),
 | |
|     staticPath("fonts/roboto/"),
 | |
|     {
 | |
|       filter: (src) => !src.includes(".") || src.endsWith(".woff2"),
 | |
|     }
 | |
|   );
 | |
| }
 | |
| 
 | |
| function copyQrScannerWorker(staticDir) {
 | |
|   const staticPath = genStaticPath(staticDir);
 | |
|   copyFileDir(npmPath("qr-scanner/qr-scanner-worker.min.js"), staticPath("js"));
 | |
| }
 | |
| 
 | |
| function copyMapPanel(staticDir) {
 | |
|   const staticPath = genStaticPath(staticDir);
 | |
|   copyFileDir(
 | |
|     npmPath("leaflet/dist/leaflet.css"),
 | |
|     staticPath("images/leaflet/")
 | |
|   );
 | |
|   copyFileDir(
 | |
|     npmPath("leaflet.markercluster/dist/MarkerCluster.css"),
 | |
|     staticPath("images/leaflet/")
 | |
|   );
 | |
|   fs.copySync(
 | |
|     npmPath("leaflet/dist/images"),
 | |
|     staticPath("images/leaflet/images/")
 | |
|   );
 | |
| }
 | |
| 
 | |
| function copyZXingWasm(staticDir) {
 | |
|   const staticPath = genStaticPath(staticDir);
 | |
|   copyFileDir(
 | |
|     npmPath("zxing-wasm/dist/reader/zxing_reader.wasm"),
 | |
|     staticPath("js")
 | |
|   );
 | |
| }
 | |
| 
 | |
| gulp.task("copy-locale-data", async () => {
 | |
|   const staticDir = paths.app_output_static;
 | |
|   copyLocaleData(staticDir);
 | |
| });
 | |
| 
 | |
| gulp.task("copy-translations-app", async () => {
 | |
|   const staticDir = paths.app_output_static;
 | |
|   copyTranslations(staticDir);
 | |
| });
 | |
| 
 | |
| gulp.task("copy-translations-supervisor", async () => {
 | |
|   const staticDir = paths.hassio_output_static;
 | |
|   copyTranslations(staticDir);
 | |
| });
 | |
| 
 | |
| gulp.task("copy-translations-landing-page", async () => {
 | |
|   const staticDir = paths.landingPage_output_static;
 | |
|   copyTranslations(staticDir);
 | |
| });
 | |
| 
 | |
| gulp.task("copy-static-supervisor", async () => {
 | |
|   const staticDir = paths.hassio_output_static;
 | |
|   copyLocaleData(staticDir);
 | |
|   copyFonts(staticDir);
 | |
| });
 | |
| 
 | |
| gulp.task("copy-static-app", async () => {
 | |
|   const staticDir = paths.app_output_static;
 | |
|   // Basic static files
 | |
|   fs.copySync(polyPath("public"), paths.app_output_root);
 | |
|   copyPolyfills(staticDir);
 | |
|   copyFonts(staticDir);
 | |
|   copyTranslations(staticDir);
 | |
|   copyLocaleData(staticDir);
 | |
|   copyMdiIcons(staticDir);
 | |
| 
 | |
|   // Panel assets
 | |
|   copyMapPanel(staticDir);
 | |
| 
 | |
|   // Qr Scanner assets
 | |
|   copyZXingWasm(staticDir);
 | |
|   copyQrScannerWorker(staticDir);
 | |
| });
 | |
| 
 | |
| gulp.task("copy-static-demo", async () => {
 | |
|   // Copy app static files
 | |
|   fs.copySync(
 | |
|     polyPath("public/static"),
 | |
|     path.resolve(paths.demo_output_root, "static")
 | |
|   );
 | |
|   // Copy demo static files
 | |
|   fs.copySync(path.resolve(paths.demo_dir, "public"), paths.demo_output_root);
 | |
|   copyPolyfills(paths.demo_output_static);
 | |
|   copyMapPanel(paths.demo_output_static);
 | |
|   copyFonts(paths.demo_output_static);
 | |
|   copyTranslations(paths.demo_output_static);
 | |
|   copyLocaleData(paths.demo_output_static);
 | |
|   copyMdiIcons(paths.demo_output_static);
 | |
| });
 | |
| 
 | |
| gulp.task("copy-static-cast", async () => {
 | |
|   // Copy app static files
 | |
|   fs.copySync(polyPath("public/static"), paths.cast_output_static);
 | |
|   // Copy cast static files
 | |
|   fs.copySync(path.resolve(paths.cast_dir, "public"), paths.cast_output_root);
 | |
|   copyPolyfills(paths.cast_output_static);
 | |
|   copyMapPanel(paths.cast_output_static);
 | |
|   copyFonts(paths.cast_output_static);
 | |
|   copyTranslations(paths.cast_output_static);
 | |
|   copyLocaleData(paths.cast_output_static);
 | |
|   copyMdiIcons(paths.cast_output_static);
 | |
| });
 | |
| 
 | |
| gulp.task("copy-static-gallery", async () => {
 | |
|   // Copy app static files
 | |
|   fs.copySync(polyPath("public/static"), paths.gallery_output_static);
 | |
|   // Copy gallery static files
 | |
|   fs.copySync(
 | |
|     path.resolve(paths.gallery_dir, "public"),
 | |
|     paths.gallery_output_root
 | |
|   );
 | |
| 
 | |
|   copyMapPanel(paths.gallery_output_static);
 | |
|   copyFonts(paths.gallery_output_static);
 | |
|   copyTranslations(paths.gallery_output_static);
 | |
|   copyLocaleData(paths.gallery_output_static);
 | |
|   copyMdiIcons(paths.gallery_output_static);
 | |
| });
 | |
| 
 | |
| gulp.task("copy-static-landing-page", async () => {
 | |
|   // Copy landing-page static files
 | |
|   fs.copySync(
 | |
|     path.resolve(paths.landingPage_dir, "public"),
 | |
|     paths.landingPage_output_root
 | |
|   );
 | |
| 
 | |
|   copyFonts(paths.landingPage_output_static);
 | |
|   copyTranslations(paths.landingPage_output_static);
 | |
| });
 |