mirror of
				https://github.com/home-assistant/frontend.git
				synced 2025-11-04 00:19:47 +00:00 
			
		
		
		
	* 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);
 | 
						|
});
 |