Compare commits

..

77 Commits

Author SHA1 Message Date
Bram Kragten
007f8b50b9 Merge pull request #5900 from home-assistant/dev 2020-05-15 22:01:34 +02:00
Bram Kragten
6fe8a87cca Bumped version to 20200515.0 2020-05-15 21:45:59 +02:00
Bram Kragten
5f46679d94 Fix mdc checkbox styling (#5897) 2020-05-15 17:56:47 +02:00
Zack Arnett
18a3f212f3 Calendar Panel: Popup Style (#5895) 2020-05-15 17:22:38 +02:00
Zack Arnett
67a3f5d87b Gauge Card: Fix if value is greater than max (#5887) 2020-05-15 17:21:53 +02:00
Bram Kragten
c88439ba2f Polyfill Intl.PluralRules (#5893) 2020-05-15 14:54:42 +02:00
Bram Kragten
67e17d4016 Fix conditional and custom panel updated > update (#5891) 2020-05-15 14:54:23 +02:00
Bram Kragten
b61cf60faf Migrate card preview to UpdatingElement (#5884) 2020-05-15 09:19:24 +02:00
HomeAssistant Azure
5503853445 [ci skip] Translation update 2020-05-15 00:32:48 +00:00
Bram Kragten
259726f5be Merge pull request #5883 from home-assistant/dev 2020-05-14 20:05:34 +02:00
Bram Kragten
bec42d941b Bumped version to 20200514.1 2020-05-14 18:46:20 +02:00
Bram Kragten
dcbbaf08f9 Set lovelace when restoring view from cache, optimise picture element and thermostat (#5880) 2020-05-14 18:44:38 +02:00
Zack Arnett
349355584a Media Player Row: Fix State Translation (#5881)
* Fix for state display translation

* Comments
2020-05-14 12:38:43 -04:00
Zack Arnett
7ce0b34774 Resizer fix (#5882) 2020-05-14 12:37:38 -04:00
Zack Arnett
dd894758a4 Card Editor: Preview Card Margin fix (#5879) 2020-05-14 18:13:26 +02:00
Zack Arnett
2aa1eb97fd Markdown Card: Fix not rendering on initial load (#5864) 2020-05-14 18:13:06 +02:00
Bram Kragten
4c43ae7b2f Beta fixes (#5878) 2020-05-14 16:03:52 +02:00
Zack Arnett
34e516e0be oops (#5866) 2020-05-14 09:26:06 +02:00
HomeAssistant Azure
7bd3427e76 [ci skip] Translation update 2020-05-14 00:32:37 +00:00
Bram Kragten
6853db693a Merge pull request #5862 from home-assistant/dev 2020-05-14 01:44:59 +02:00
Bram Kragten
252ce1e467 Show loading screen for integration config (#5863) 2020-05-14 01:44:39 +02:00
Bram Kragten
221c12bd61 Bumped version to 20200514.0 2020-05-14 01:12:57 +02:00
Paulus Schoutsen
12edd68874 Remove unused ES5 service worker (#5860) 2020-05-14 01:11:32 +02:00
Bram Kragten
f469753fb1 Dont add all childs at once to view (#5856) 2020-05-14 00:09:52 +02:00
Bram Kragten
c894ecd0e6 Optimise sourcemaps (#5859) 2020-05-14 00:06:39 +02:00
Paulus Schoutsen
2153bc536c Clean up service worker code and fix 404 (#5855) 2020-05-13 13:17:47 -07:00
Bram Kragten
86bbac430c Fix translations for integration config panel (#5854) 2020-05-13 20:49:01 +02:00
Bram Kragten
16ad8a3c01 Open newly added view after adding (#5851) 2020-05-13 19:49:03 +02:00
Bram Kragten
b2af91c83e Fixes for problems caused by not rebuilding (#5850) 2020-05-13 18:51:26 +02:00
Bram Kragten
4c0810f530 Fix typo in property method (#5852) 2020-05-13 18:51:16 +02:00
Paulus Schoutsen
f70130e21f Remove reference to Google Fonts (#5849) 2020-05-13 18:22:53 +02:00
Paulus Schoutsen
6bb7b01d00 Fix demo size_stats 2020-05-13 08:41:35 -07:00
Bram Kragten
51e7aaa805 Merge pull request #5848 from home-assistant/dev 2020-05-13 13:14:23 +02:00
Bram Kragten
54704e53b3 Bumped version to 20200513.0 2020-05-13 12:47:37 +02:00
Bram Kragten
cc46797576 Some fixes in focus and click handling (#5847) 2020-05-13 12:47:09 +02:00
Bram Kragten
7f1fb6f75f Set edit mode to false on card when disabling edit mode. (#5845) 2020-05-13 12:05:29 +02:00
Bram Kragten
2c2a1d204b Graph history fix (#5846) 2020-05-13 12:05:03 +02:00
Paulus Schoutsen
581fafdcc9 Workbox 5 in gulp (#5843) 2020-05-13 11:12:01 +02:00
HomeAssistant Azure
10358abbec [ci skip] Translation update 2020-05-13 00:32:49 +00:00
Bram Kragten
de1ffe67b1 Merge pull request #5840 from home-assistant/dev 2020-05-12 22:24:40 +02:00
Zack Arnett
eb2b24d57c Weather Card: Fix overwritten changes (#5841) 2020-05-12 22:24:20 +02:00
Bram Kragten
825db8a56a Bumped version to 20200512.0 2020-05-12 21:59:06 +02:00
David F. Mulcahey
577a21fc5c Rework ZHA group adds and removes (#5602) 2020-05-12 21:42:29 +02:00
Bram Kragten
1b2841eef9 Recreate cards only on config change (#5839) 2020-05-12 11:09:30 -07:00
Ian Richardson
845511e322 Add 'brightness' as a secondary_info option (#5731) 2020-05-12 12:29:43 -04:00
Bram Kragten
96ab057853 Ignore ResizeObserver loop limit exceeded error (#5838) 2020-05-12 12:17:41 +02:00
HomeAssistant Azure
f85cf0a238 [ci skip] Translation update 2020-05-12 00:33:00 +00:00
Bram Kragten
84a2676a9c compress icons (#5836) 2020-05-11 23:59:29 +02:00
Zack Arnett
466a1af902 Weather Card/Row: Weather Icons as SVG, Themeable, user definable (#5736)
* SVG

* no-unneeded-ternary

* declared ubnused

* moving stuff around

* Few updates

* All svgs in | update row

* No slots

* Remove public/static/images/weather

* style for user defined

* few updates to missing fils

* classes

* wind color
2020-05-11 23:58:17 +02:00
Zack Arnett
ebbe7e805f Gauge Card: Convert to Round Slider (#5510)
* Use round slider for gauge

* Update guage to slider

* Add severity back

* Remove Base Unit

* fix merge

* resize observer

* Update src/panels/lovelace/cards/hui-gauge-card.ts

Co-authored-by: Bram Kragten <mail@bramkragten.nl>

* Update Install Resize Observer to be a helper

* Type import

* Reviews

* Updates to other cards

Co-authored-by: Bram Kragten <mail@bramkragten.nl>
2020-05-11 17:14:02 -04:00
Zack Arnett
c861ee025e Weather Card: Ability to choose Secondary Attribute (#5820) 2020-05-11 22:11:48 +02:00
Paulus Schoutsen
6d0823328d Fix generated Lovelace translating domain names (#5803) 2020-05-11 10:28:05 -07:00
Joakim Sørensen
60be14dc77 Use manifest.issue_tracker for issues URL if not built_in (#5818) 2020-05-11 13:45:00 +02:00
Mat Strange
2d627819d9 Added translation to dev-tools-info-integrations (#5834) 2020-05-11 13:44:32 +02:00
Zack Arnett
cf575f83f5 Weather Card: Switch State and Name (#5795) 2020-05-11 13:44:15 +02:00
HomeAssistant Azure
79935b2d4c [ci skip] Translation update 2020-05-11 00:32:59 +00:00
HomeAssistant Azure
d1cceb2013 [ci skip] Translation update 2020-05-10 00:33:23 +00:00
Bram Kragten
f5da130d51 Merge pull request #5823 from matstrange/dev 2020-05-09 22:18:37 +02:00
Mat Strange
8768304ec5 Returned to no label on disarm/trigger as before 2020-05-09 20:30:44 +01:00
Bram Kragten
f10a5dcdbe Unused import 2020-05-09 21:22:46 +02:00
Bram Kragten
a27428ebcd Simplify enter handling 2020-05-09 21:17:55 +02:00
Bram Kragten
d19acf17c2 Merge pull request #5826 from home-assistant/dev 2020-05-09 21:17:30 +02:00
Bram Kragten
1a0bf861ee Bumped version to 20200509.0 2020-05-09 21:01:00 +02:00
Bram Kragten
db906ad4d0 Bump material (#5812) 2020-05-09 20:59:53 +02:00
Bram Kragten
75ed0f2f99 Fix translation download and add empty languages (#5824) 2020-05-09 20:59:34 +02:00
Bram Kragten
29ed1144d5 Simplify custom icon set, return only 1 icon per call (#5822) 2020-05-09 20:59:02 +02:00
Mat Strange
fa445d4066 Added translation to bade on alarm panel 2020-05-09 12:00:26 +01:00
Erik Montnemery
d10be4ef2d Show cover position slider if cover supports it (#5815) 2020-05-08 22:59:20 +02:00
Joakim Sørensen
7f66d5b8e9 Change target to currentTarget for the click event (#5816) 2020-05-08 16:31:07 -04:00
Bram Kragten
0c8cd680c2 Allow custom icon sets (#5794) 2020-05-08 21:56:25 +02:00
Maciej Bieniek
a7ba1977b4 Add translation for and word on the integration card (#5811)
* Add translation for and word on tje integration card

* Move and to ui.common
2020-05-08 17:43:21 +02:00
Bram Kragten
a960b39235 Bump lit-element and lit-html (#5810) 2020-05-08 14:00:09 +02:00
Bram Kragten
3febf059ec Codesplit Supervisor panel icons (#5809) 2020-05-08 13:10:24 +02:00
Paulus Schoutsen
20203f7bdb Bump home-assistant-js-websocket to 5.1.2 2020-05-07 18:35:14 -07:00
Franck Nijhof
a399d76d06 Add new core configuration UI for external_url & internal_url (#5755) 2020-05-07 18:32:03 -07:00
Franck Nijhof
1ca097c5a0 Add issue_tracker integration manifest property (#5744) 2020-05-07 20:51:46 -04:00
Bram Kragten
ae6243b7bf Merge pull request #5757 from home-assistant/dev 2020-05-05 17:38:14 +02:00
491 changed files with 9323 additions and 4619 deletions

View File

@@ -69,7 +69,7 @@
"import/extensions": [ "import/extensions": [
2, 2,
"ignorePackages", "ignorePackages",
{ "ts": "ignorePackages", "js": "ignorePackages" } { "ts": "never", "js": "never" }
], ],
"no-restricted-syntax": ["error", "LabeledStatement", "WithStatement"], "no-restricted-syntax": ["error", "LabeledStatement", "WithStatement"],
"object-curly-newline": 0, "object-curly-newline": 0,

View File

@@ -24,7 +24,6 @@ const options = ({ latestBuild }) => ({
], ],
}); });
module.exports.options = options;
module.exports.babelLoaderConfig = ({ latestBuild }) => { module.exports.babelLoaderConfig = ({ latestBuild }) => {
if (latestBuild === undefined) { if (latestBuild === undefined) {
throw Error("latestBuild not defined for babel loader config"); throw Error("latestBuild not defined for babel loader config");

View File

@@ -20,7 +20,7 @@ gulp.task(
}, },
"clean", "clean",
gulp.parallel( gulp.parallel(
"gen-service-worker-dev", "gen-service-worker-app-dev",
"gen-icons-json", "gen-icons-json",
"gen-pages-dev", "gen-pages-dev",
"gen-index-app-dev", "gen-index-app-dev",
@@ -46,7 +46,7 @@ gulp.task(
gulp.parallel( gulp.parallel(
"gen-pages-prod", "gen-pages-prod",
"gen-index-app-prod", "gen-index-app-prod",
"gen-service-worker-prod" "gen-service-worker-app-prod"
) )
) )
); );

View File

@@ -9,25 +9,30 @@ const paths = require("../paths");
gulp.task("compress-app", function compressApp() { gulp.task("compress-app", function compressApp() {
const jsLatest = gulp const jsLatest = gulp
.src(path.resolve(paths.output, "**/*.js")) .src(path.resolve(paths.output, "**/*.js"))
.pipe(zopfli()) .pipe(zopfli({ threshold: 150 }))
.pipe(gulp.dest(paths.output)); .pipe(gulp.dest(paths.output));
const jsEs5 = gulp const jsEs5 = gulp
.src(path.resolve(paths.output_es5, "**/*.js")) .src(path.resolve(paths.output_es5, "**/*.js"))
.pipe(zopfli()) .pipe(zopfli({ threshold: 150 }))
.pipe(gulp.dest(paths.output_es5)); .pipe(gulp.dest(paths.output_es5));
const polyfills = gulp const polyfills = gulp
.src(path.resolve(paths.static, "polyfills/*.js")) .src(path.resolve(paths.static, "polyfills/*.js"))
.pipe(zopfli()) .pipe(zopfli({ threshold: 150 }))
.pipe(gulp.dest(path.resolve(paths.static, "polyfills"))); .pipe(gulp.dest(path.resolve(paths.static, "polyfills")));
const translations = gulp const translations = gulp
.src(path.resolve(paths.static, "translations/*.json")) .src(path.resolve(paths.static, "translations/**/*.json"))
.pipe(zopfli()) .pipe(zopfli({ threshold: 150 }))
.pipe(gulp.dest(path.resolve(paths.static, "translations"))); .pipe(gulp.dest(path.resolve(paths.static, "translations")));
return merge(jsLatest, jsEs5, polyfills, translations); const icons = gulp
.src(path.resolve(paths.static, "mdi/*.json"))
.pipe(zopfli({ threshold: 150 }))
.pipe(gulp.dest(path.resolve(paths.static, "mdi")));
return merge(jsLatest, jsEs5, polyfills, translations, icons);
}); });
gulp.task("compress-hassio", function compressApp() { gulp.task("compress-hassio", function compressApp() {

View File

@@ -1,9 +1,14 @@
const del = require("del"); const del = require("del");
const gulp = require("gulp"); const gulp = require("gulp");
const fs = require("fs");
const mapStream = require("map-stream"); const mapStream = require("map-stream");
const inDir = "translations/frontend"; const inDirFrontend = "translations/frontend";
const downloadDir = inDir + "/downloads"; const inDirBackend = "translations/backend";
const downloadDir = "translations/downloads";
const srcMeta = "src/translations/translationMetadata.json";
const encoding = "utf8";
const tasks = []; const tasks = [];
@@ -53,9 +58,25 @@ gulp.task(taskName, function () {
}); });
tasks.push(taskName); tasks.push(taskName);
taskName = "check-all-files-exist";
gulp.task(taskName, function () {
const file = fs.readFileSync(srcMeta, { encoding });
const meta = JSON.parse(file);
Object.keys(meta).forEach((lang) => {
if (!fs.existsSync(`${inDirFrontend}/${lang}.json`)) {
fs.writeFileSync(`${inDirFrontend}/${lang}.json`, JSON.stringify({}));
}
if (!fs.existsSync(`${inDirBackend}/${lang}.json`)) {
fs.writeFileSync(`${inDirBackend}/${lang}.json`, JSON.stringify({}));
}
});
return Promise.resolve();
});
tasks.push(taskName);
taskName = "move-downloaded-translations"; taskName = "move-downloaded-translations";
gulp.task(taskName, function () { gulp.task(taskName, function () {
return gulp.src(`${downloadDir}/*.json`).pipe(gulp.dest(inDir)); return gulp.src(`${downloadDir}/*.json`).pipe(gulp.dest(inDirFrontend));
}); });
tasks.push(taskName); tasks.push(taskName);
@@ -65,6 +86,7 @@ gulp.task(
gulp.series( gulp.series(
"check-translations-html", "check-translations-html",
"move-downloaded-translations", "move-downloaded-translations",
"check-all-files-exist",
"clean-downloaded-translations" "clean-downloaded-translations"
) )
); );

View File

@@ -5,18 +5,22 @@
const gulp = require("gulp"); const gulp = require("gulp");
const path = require("path"); const path = require("path");
const fs = require("fs-extra"); const fs = require("fs-extra");
const config = require("../paths.js"); const workboxBuild = require("workbox-build");
const sourceMapUrl = require("source-map-url");
const paths = require("../paths.js");
const swPath = path.resolve(config.root, "service_worker.js"); const swDest = path.resolve(paths.root, "service_worker.js");
const writeSW = (content) => fs.outputFileSync(swPath, content.trim() + "\n"); const writeSW = (content) => fs.outputFileSync(swDest, content.trim() + "\n");
gulp.task("gen-service-worker-dev", (done) => { gulp.task("gen-service-worker-app-dev", (done) => {
writeSW( writeSW(
` `
console.debug('Service worker disabled in development'); console.debug('Service worker disabled in development');
self.addEventListener('install', (event) => { self.addEventListener('install', (event) => {
// This will activate the dev service worker,
// removing any prod service worker the dev might have running
self.skipWaiting(); self.skipWaiting();
}); });
` `
@@ -24,10 +28,63 @@ self.addEventListener('install', (event) => {
done(); done();
}); });
gulp.task("gen-service-worker-prod", (done) => { gulp.task("gen-service-worker-app-prod", async () => {
fs.copySync( // Read bundled source file
path.resolve(config.output, "service_worker.js"), const bundleManifestLatest = require(path.resolve(
path.resolve(config.root, "service_worker.js") paths.output,
"manifest.json"
));
let serviceWorkerContent = fs.readFileSync(
paths.root + bundleManifestLatest["service_worker.js"],
"utf-8"
); );
done();
// Delete old file from frontend_latest so manifest won't pick it up
fs.removeSync(paths.root + bundleManifestLatest["service_worker.js"]);
fs.removeSync(paths.root + bundleManifestLatest["service_worker.js.map"]);
// Remove ES5
const bundleManifestES5 = require(path.resolve(
paths.output_es5,
"manifest.json"
));
fs.removeSync(paths.root + bundleManifestES5["service_worker.js"]);
fs.removeSync(paths.root + bundleManifestES5["service_worker.js.map"]);
const workboxManifest = await workboxBuild.getManifest({
// Files that mach this pattern will be considered unique and skip revision check
// ignore JS files + translation files
dontCacheBustURLsMatching: /(frontend_latest\/.+|static\/translations\/.+)/,
globDirectory: paths.root,
globPatterns: [
"frontend_latest/*.js",
// Cache all English translations because we catch them as fallback
// Using pattern to match hash instead of * to avoid caching en-GB
// 'v' added as valid hash letter because in dev we hash with 'dev'
"static/translations/**/en-+([a-fv0-9]).json",
// Icon shown on splash screen
"static/icons/favicon-192x192.png",
"static/icons/favicon.ico",
// Common fonts
"static/fonts/roboto/Roboto-Light.woff2",
"static/fonts/roboto/Roboto-Medium.woff2",
"static/fonts/roboto/Roboto-Regular.woff2",
"static/fonts/roboto/Roboto-Bold.woff2",
],
});
for (const warning of workboxManifest.warnings) {
console.warn(warning);
}
// remove source map and add WB manifest
serviceWorkerContent = sourceMapUrl.removeFrom(serviceWorkerContent);
serviceWorkerContent = serviceWorkerContent.replace(
"WB_MANIFEST",
JSON.stringify(workboxManifest.manifestEntries)
);
// Write new file to root
fs.writeFileSync(swDest, serviceWorkerContent);
}); });

View File

@@ -1,7 +1,6 @@
const webpack = require("webpack"); const webpack = require("webpack");
const path = require("path"); const path = require("path");
const TerserPlugin = require("terser-webpack-plugin"); const TerserPlugin = require("terser-webpack-plugin");
const WorkboxPlugin = require("workbox-webpack-plugin");
const ManifestPlugin = require("webpack-manifest-plugin"); const ManifestPlugin = require("webpack-manifest-plugin");
const paths = require("./paths.js"); const paths = require("./paths.js");
const env = require("./env.js"); const env = require("./env.js");
@@ -21,7 +20,9 @@ const createWebpackConfig = ({
} }
return { return {
mode: isProdBuild ? "production" : "development", mode: isProdBuild ? "production" : "development",
devtool: isProdBuild ? "source-map" : "inline-cheap-module-source-map", devtool: isProdBuild
? "cheap-module-source-map"
: "eval-cheap-module-source-map",
entry, entry,
module: { module: {
rules: [ rules: [
@@ -75,6 +76,10 @@ const createWebpackConfig = ({
/@polymer\/font-roboto\/roboto\.js$/, /@polymer\/font-roboto\/roboto\.js$/,
path.resolve(paths.polymer_dir, "src/util/empty.js") path.resolve(paths.polymer_dir, "src/util/empty.js")
), ),
new webpack.NormalModuleReplacementPlugin(
/@vaadin\/vaadin-material-styles\/font-roboto\.js$/,
path.resolve(paths.polymer_dir, "src/util/empty.js")
),
// Ignore mwc icons pointing at CDN. // Ignore mwc icons pointing at CDN.
new webpack.NormalModuleReplacementPlugin( new webpack.NormalModuleReplacementPlugin(
/@material\/mwc-icon\/mwc-icon-font\.js$/, /@material\/mwc-icon\/mwc-icon-font\.js$/,
@@ -107,8 +112,9 @@ const createWebpackConfig = ({
}; };
const createAppConfig = ({ isProdBuild, latestBuild, isStatsBuild }) => { const createAppConfig = ({ isProdBuild, latestBuild, isStatsBuild }) => {
const config = createWebpackConfig({ return createWebpackConfig({
entry: { entry: {
service_worker: "./src/entrypoints/service_worker.ts",
app: "./src/entrypoints/app.ts", app: "./src/entrypoints/app.ts",
authorize: "./src/entrypoints/authorize.ts", authorize: "./src/entrypoints/authorize.ts",
onboarding: "./src/entrypoints/onboarding.ts", onboarding: "./src/entrypoints/onboarding.ts",
@@ -121,48 +127,6 @@ const createAppConfig = ({ isProdBuild, latestBuild, isStatsBuild }) => {
latestBuild, latestBuild,
isStatsBuild, isStatsBuild,
}); });
if (latestBuild) {
// Create an object mapping browser urls to their paths during build
const translationMetadata = require("../build-translations/translationMetadata.json");
const workBoxTranslationsTemplatedURLs = {};
const englishFilename = `en-${translationMetadata.translations.en.hash}.json`;
// core
workBoxTranslationsTemplatedURLs[
`/static/translations/${englishFilename}`
] = `build-translations/output/${englishFilename}`;
translationMetadata.fragments.forEach((fragment) => {
workBoxTranslationsTemplatedURLs[
`/static/translations/${fragment}/${englishFilename}`
] = `build-translations/output/${fragment}/${englishFilename}`;
});
config.plugins.push(
new WorkboxPlugin.InjectManifest({
swSrc: "./src/entrypoints/service-worker-hass.js",
swDest: "service_worker.js",
importWorkboxFrom: "local",
include: [/\.js$/],
templatedURLs: {
...workBoxTranslationsTemplatedURLs,
"/static/icons/favicon-192x192.png":
"public/icons/favicon-192x192.png",
"/static/fonts/roboto/Roboto-Light.woff2":
"node_modules/roboto-fontface/fonts/roboto/Roboto-Light.woff2",
"/static/fonts/roboto/Roboto-Medium.woff2":
"node_modules/roboto-fontface/fonts/roboto/Roboto-Medium.woff2",
"/static/fonts/roboto/Roboto-Regular.woff2":
"node_modules/roboto-fontface/fonts/roboto/Roboto-Regular.woff2",
"/static/fonts/roboto/Roboto-Bold.woff2":
"node_modules/roboto-fontface/fonts/roboto/Roboto-Bold.woff2",
},
})
);
}
return config;
}; };
const createDemoConfig = ({ isProdBuild, latestBuild, isStatsBuild }) => { const createDemoConfig = ({ isProdBuild, latestBuild, isStatsBuild }) => {

View File

@@ -184,7 +184,7 @@ export class HcConnect extends LitElement {
this.castManager = null; this.castManager = null;
} }
); );
registerServiceWorker(false); registerServiceWorker(this, false);
} }
private async _handleDemo() { private async _handleDemo() {

View File

@@ -7,5 +7,5 @@ set -e
cd "$(dirname "$0")/.." cd "$(dirname "$0")/.."
STATS=1 NODE_ENV=production ../node_modules/.bin/webpack --profile --json > compilation-stats.json STATS=1 NODE_ENV=production ../node_modules/.bin/webpack --profile --json > compilation-stats.json
npx webpack-bundle-analyzer compilation-stats.json dist npx webpack-bundle-analyzer compilation-stats.json dist/frontend_latest
rm compilation-stats.json rm compilation-stats.json

View File

@@ -1,4 +1,4 @@
import "@polymer/paper-card/paper-card"; import { mdiArrowUpBoldCircle, mdiPuzzle } from "@mdi/js";
import { import {
css, css,
CSSResultArray, CSSResultArray,
@@ -10,6 +10,7 @@ import {
import memoizeOne from "memoize-one"; import memoizeOne from "memoize-one";
import { atLeastVersion } from "../../../src/common/config/version"; import { atLeastVersion } from "../../../src/common/config/version";
import { navigate } from "../../../src/common/navigate"; import { navigate } from "../../../src/common/navigate";
import "../../../src/components/ha-card";
import { import {
HassioAddonInfo, HassioAddonInfo,
HassioAddonRepository, HassioAddonRepository,
@@ -66,7 +67,7 @@ class HassioAddonRepositoryEl extends LitElement {
<div class="card-group"> <div class="card-group">
${addons.map( ${addons.map(
(addon) => html` (addon) => html`
<paper-card <ha-card
.addon=${addon} .addon=${addon}
class=${addon.available ? "" : "not_available"} class=${addon.available ? "" : "not_available"}
@click=${this._addonTapped} @click=${this._addonTapped}
@@ -78,8 +79,8 @@ class HassioAddonRepositoryEl extends LitElement {
.description=${addon.description} .description=${addon.description}
.available=${addon.available} .available=${addon.available}
.icon=${addon.installed && addon.installed !== addon.version .icon=${addon.installed && addon.installed !== addon.version
? "hassio:arrow-up-bold-circle" ? mdiArrowUpBoldCircle
: "hassio:puzzle"} : mdiPuzzle}
.iconTitle=${addon.installed .iconTitle=${addon.installed
? addon.installed !== addon.version ? addon.installed !== addon.version
? "New version available" ? "New version available"
@@ -111,7 +112,7 @@ class HassioAddonRepositoryEl extends LitElement {
: ""} : ""}
></hassio-card-content> ></hassio-card-content>
</div> </div>
</paper-card> </ha-card>
` `
)} )}
</div> </div>
@@ -127,7 +128,7 @@ class HassioAddonRepositoryEl extends LitElement {
return [ return [
hassioStyle, hassioStyle,
css` css`
paper-card { ha-card {
cursor: pointer; cursor: pointer;
} }
.not_available { .not_available {

View File

@@ -1,3 +1,6 @@
import "@material/mwc-icon-button/mwc-icon-button";
import "@material/mwc-list/mwc-list-item";
import { mdiDotsVertical } from "@mdi/js";
import { import {
css, css,
CSSResult, CSSResult,
@@ -6,22 +9,21 @@ import {
PropertyValues, PropertyValues,
} from "lit-element"; } from "lit-element";
import { html, TemplateResult } from "lit-html"; import { html, TemplateResult } from "lit-html";
import "../../../src/common/search/search-input";
import "../../../src/components/ha-button-menu";
import "../../../src/components/ha-svg-icon";
import { import {
fetchHassioAddonsInfo, fetchHassioAddonsInfo,
HassioAddonInfo, HassioAddonInfo,
HassioAddonRepository, HassioAddonRepository,
reloadHassioAddons, reloadHassioAddons,
} from "../../../src/data/hassio/addon"; } from "../../../src/data/hassio/addon";
import "../../../src/components/ha-icon-button";
import "../../../src/layouts/loading-screen";
import "../../../src/layouts/hass-tabs-subpage"; import "../../../src/layouts/hass-tabs-subpage";
import "../../../src/layouts/loading-screen";
import { HomeAssistant, Route } from "../../../src/types"; import { HomeAssistant, Route } from "../../../src/types";
import "../../../src/common/search/search-input";
import "./hassio-addon-repository";
import { supervisorTabs } from "../hassio-panel";
import { showRepositoriesDialog } from "../dialogs/repositories/show-dialog-repositories"; import { showRepositoriesDialog } from "../dialogs/repositories/show-dialog-repositories";
import { supervisorTabs } from "../hassio-panel";
import "./hassio-addon-repository";
const sortRepos = (a: HassioAddonRepository, b: HassioAddonRepository) => { const sortRepos = (a: HassioAddonRepository, b: HassioAddonRepository) => {
if (a.slug === "local") { if (a.slug === "local") {
@@ -94,27 +96,17 @@ class HassioAddonStore extends LitElement {
.tabs=${supervisorTabs} .tabs=${supervisorTabs}
> >
<span slot="header">Add-on store</span> <span slot="header">Add-on store</span>
<paper-menu-button <ha-button-menu corner="BOTTOM_START" slot="toolbar-icon">
close-on-activate <mwc-icon-button slot="trigger" alt="menu">
no-animations <ha-svg-icon path=${mdiDotsVertical}></ha-svg-icon>
horizontal-align="right" </mwc-icon-button>
horizontal-offset="-5" <mwc-list-item @tap=${this._manageRepositories}>
slot="toolbar-icon" Repositories
> </mwc-list-item>
<ha-icon-button <mwc-list-item @tap=${this.refreshData}>
icon="hassio:dots-vertical" Reload
slot="dropdown-trigger" </mwc-list-item>
alt="menu" </ha-button-menu>
></ha-icon-button>
<paper-listbox slot="dropdown-content" role="listbox">
<paper-item @tap=${this._manageRepositories}>
Repositories
</paper-item>
<paper-item @tap=${this.refreshData}>
Reload
</paper-item>
</paper-listbox>
</paper-menu-button>
${repos.length === 0 ${repos.length === 0
? html`<loading-screen></loading-screen>` ? html`<loading-screen></loading-screen>`
: html` : html`

View File

@@ -1,5 +1,4 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/paper-card/paper-card";
import "@polymer/paper-dropdown-menu/paper-dropdown-menu"; import "@polymer/paper-dropdown-menu/paper-dropdown-menu";
import "@polymer/paper-item/paper-item"; import "@polymer/paper-item/paper-item";
import "@polymer/paper-listbox/paper-listbox"; import "@polymer/paper-listbox/paper-listbox";
@@ -14,6 +13,7 @@ import {
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import "web-animations-js/web-animations-next-lite.min"; import "web-animations-js/web-animations-next-lite.min";
import "../../../../src/components/ha-card";
import { import {
HassioAddonDetails, HassioAddonDetails,
HassioAddonSetOptionParams, HassioAddonSetOptionParams,
@@ -23,9 +23,9 @@ import {
fetchHassioHardwareAudio, fetchHassioHardwareAudio,
HassioHardwareAudioDevice, HassioHardwareAudioDevice,
} from "../../../../src/data/hassio/hardware"; } from "../../../../src/data/hassio/hardware";
import { suggestAddonRestart } from "../../dialogs/suggestAddonRestart";
import { haStyle } from "../../../../src/resources/styles"; import { haStyle } from "../../../../src/resources/styles";
import { HomeAssistant } from "../../../../src/types"; import { HomeAssistant } from "../../../../src/types";
import { suggestAddonRestart } from "../../dialogs/suggestAddonRestart";
import { hassioStyle } from "../../resources/hassio-style"; import { hassioStyle } from "../../resources/hassio-style";
@customElement("hassio-addon-audio") @customElement("hassio-addon-audio")
@@ -46,7 +46,7 @@ class HassioAddonAudio extends LitElement {
protected render(): TemplateResult { protected render(): TemplateResult {
return html` return html`
<paper-card heading="Audio"> <ha-card header="Audio">
<div class="card-content"> <div class="card-content">
${this._error ? html` <div class="errors">${this._error}</div> ` : ""} ${this._error ? html` <div class="errors">${this._error}</div> ` : ""}
@@ -92,7 +92,7 @@ class HassioAddonAudio extends LitElement {
<div class="card-actions"> <div class="card-actions">
<mwc-button @click=${this._saveSettings}>Save</mwc-button> <mwc-button @click=${this._saveSettings}>Save</mwc-button>
</div> </div>
</paper-card> </ha-card>
`; `;
} }
@@ -102,7 +102,7 @@ class HassioAddonAudio extends LitElement {
hassioStyle, hassioStyle,
css` css`
:host, :host,
paper-card, ha-card,
paper-dropdown-menu { paper-dropdown-menu {
display: block; display: block;
} }

View File

@@ -8,12 +8,10 @@ import {
property, property,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { HomeAssistant } from "../../../../src/types";
import { HassioAddonDetails } from "../../../../src/data/hassio/addon"; import { HassioAddonDetails } from "../../../../src/data/hassio/addon";
import { hassioStyle } from "../../resources/hassio-style";
import { haStyle } from "../../../../src/resources/styles"; import { haStyle } from "../../../../src/resources/styles";
import { HomeAssistant } from "../../../../src/types";
import { hassioStyle } from "../../resources/hassio-style";
import "./hassio-addon-audio"; import "./hassio-addon-audio";
import "./hassio-addon-config"; import "./hassio-addon-config";
import "./hassio-addon-network"; import "./hassio-addon-network";

View File

@@ -1,6 +1,5 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/iron-autogrow-textarea/iron-autogrow-textarea"; import "@polymer/iron-autogrow-textarea/iron-autogrow-textarea";
import "@polymer/paper-card/paper-card";
import { import {
css, css,
CSSResult, CSSResult,
@@ -13,6 +12,7 @@ import {
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { fireEvent } from "../../../../src/common/dom/fire_event"; import { fireEvent } from "../../../../src/common/dom/fire_event";
import "../../../../src/components/ha-card";
import "../../../../src/components/ha-yaml-editor"; import "../../../../src/components/ha-yaml-editor";
import type { HaYamlEditor } from "../../../../src/components/ha-yaml-editor"; import type { HaYamlEditor } from "../../../../src/components/ha-yaml-editor";
import { import {
@@ -23,9 +23,8 @@ import {
import { showConfirmationDialog } from "../../../../src/dialogs/generic/show-dialog-box"; import { showConfirmationDialog } from "../../../../src/dialogs/generic/show-dialog-box";
import { haStyle } from "../../../../src/resources/styles"; import { haStyle } from "../../../../src/resources/styles";
import type { HomeAssistant } from "../../../../src/types"; import type { HomeAssistant } from "../../../../src/types";
import { hassioStyle } from "../../resources/hassio-style";
import { suggestAddonRestart } from "../../dialogs/suggestAddonRestart"; import { suggestAddonRestart } from "../../dialogs/suggestAddonRestart";
import { hassioStyle } from "../../resources/hassio-style";
@customElement("hassio-addon-config") @customElement("hassio-addon-config")
class HassioAddonConfig extends LitElement { class HassioAddonConfig extends LitElement {
@@ -46,7 +45,7 @@ class HassioAddonConfig extends LitElement {
return html` return html`
<h1>${this.addon.name}</h1> <h1>${this.addon.name}</h1>
<paper-card heading="Configuration"> <ha-card header="Configuration">
<div class="card-content"> <div class="card-content">
<ha-yaml-editor <ha-yaml-editor
@value-changed=${this._configChanged} @value-changed=${this._configChanged}
@@ -65,7 +64,7 @@ class HassioAddonConfig extends LitElement {
Save Save
</mwc-button> </mwc-button>
</div> </div>
</paper-card> </ha-card>
`; `;
} }
@@ -77,7 +76,7 @@ class HassioAddonConfig extends LitElement {
:host { :host {
display: block; display: block;
} }
paper-card { ha-card {
display: block; display: block;
} }
.card-actions { .card-actions {

View File

@@ -1,4 +1,3 @@
import "@polymer/paper-card/paper-card";
import { PaperInputElement } from "@polymer/paper-input/paper-input"; import { PaperInputElement } from "@polymer/paper-input/paper-input";
import { import {
css, css,
@@ -11,15 +10,15 @@ import {
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { fireEvent } from "../../../../src/common/dom/fire_event"; import { fireEvent } from "../../../../src/common/dom/fire_event";
import "../../../../src/components/ha-card";
import { import {
HassioAddonDetails, HassioAddonDetails,
HassioAddonSetOptionParams, HassioAddonSetOptionParams,
setHassioAddonOption, setHassioAddonOption,
} from "../../../../src/data/hassio/addon"; } from "../../../../src/data/hassio/addon";
import { suggestAddonRestart } from "../../dialogs/suggestAddonRestart";
import { haStyle } from "../../../../src/resources/styles"; import { haStyle } from "../../../../src/resources/styles";
import { HomeAssistant } from "../../../../src/types"; import { HomeAssistant } from "../../../../src/types";
import { suggestAddonRestart } from "../../dialogs/suggestAddonRestart";
import { hassioStyle } from "../../resources/hassio-style"; import { hassioStyle } from "../../resources/hassio-style";
interface NetworkItem { interface NetworkItem {
@@ -53,7 +52,7 @@ class HassioAddonNetwork extends LitElement {
} }
return html` return html`
<paper-card heading="Network"> <ha-card header="Network">
<div class="card-content"> <div class="card-content">
${this._error ? html` <div class="errors">${this._error}</div> ` : ""} ${this._error ? html` <div class="errors">${this._error}</div> ` : ""}
@@ -90,7 +89,7 @@ class HassioAddonNetwork extends LitElement {
</mwc-button> </mwc-button>
<mwc-button @click=${this._saveTapped}>Save</mwc-button> <mwc-button @click=${this._saveTapped}>Save</mwc-button>
</div> </div>
</paper-card> </ha-card>
`; `;
} }
@@ -102,7 +101,7 @@ class HassioAddonNetwork extends LitElement {
:host { :host {
display: block; display: block;
} }
paper-card { ha-card {
display: block; display: block;
} }
.errors { .errors {

View File

@@ -1,5 +1,4 @@
import "@polymer/paper-spinner/paper-spinner-lite"; import "@polymer/paper-spinner/paper-spinner-lite";
import "@polymer/paper-card/paper-card";
import { import {
css, css,
CSSResult, CSSResult,
@@ -9,16 +8,15 @@ import {
property, property,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { HomeAssistant } from "../../../../src/types";
import {
HassioAddonDetails,
fetchHassioAddonDocumentation,
} from "../../../../src/data/hassio/addon";
import "../../../../src/components/ha-markdown"; import "../../../../src/components/ha-markdown";
import {
fetchHassioAddonDocumentation,
HassioAddonDetails,
} from "../../../../src/data/hassio/addon";
import "../../../../src/layouts/loading-screen"; import "../../../../src/layouts/loading-screen";
import { hassioStyle } from "../../resources/hassio-style";
import { haStyle } from "../../../../src/resources/styles"; import { haStyle } from "../../../../src/resources/styles";
import { HomeAssistant } from "../../../../src/types";
import { hassioStyle } from "../../resources/hassio-style";
@customElement("hassio-addon-documentation-tab") @customElement("hassio-addon-documentation-tab")
class HassioAddonDocumentationDashboard extends LitElement { class HassioAddonDocumentationDashboard extends LitElement {
@@ -41,14 +39,14 @@ class HassioAddonDocumentationDashboard extends LitElement {
} }
return html` return html`
<div class="content"> <div class="content">
<paper-card> <ha-card>
${this._error ? html` <div class="errors">${this._error}</div> ` : ""} ${this._error ? html` <div class="errors">${this._error}</div> ` : ""}
<div class="card-content"> <div class="card-content">
${this._content ${this._content
? html`<ha-markdown .content=${this._content}></ha-markdown>` ? html`<ha-markdown .content=${this._content}></ha-markdown>`
: html`<loading-screen></loading-screen>`} : html`<loading-screen></loading-screen>`}
</div> </div>
</paper-card> </ha-card>
</div> </div>
`; `;
} }
@@ -58,7 +56,7 @@ class HassioAddonDocumentationDashboard extends LitElement {
haStyle, haStyle,
hassioStyle, hassioStyle,
css` css`
paper-card { ha-card {
display: block; display: block;
} }
.content { .content {

View File

@@ -1,4 +1,9 @@
import "../../../src/components/ha-icon-button"; import {
mdiCogs,
mdiFileDocument,
mdiInformationVariant,
mdiMathLog,
} from "@mdi/js";
import "@polymer/paper-spinner/paper-spinner-lite"; import "@polymer/paper-spinner/paper-spinner-lite";
import { import {
css, css,
@@ -14,18 +19,17 @@ import {
fetchHassioAddonInfo, fetchHassioAddonInfo,
HassioAddonDetails, HassioAddonDetails,
} from "../../../src/data/hassio/addon"; } from "../../../src/data/hassio/addon";
import "../../../src/layouts/hass-tabs-subpage";
import type { PageNavigation } from "../../../src/layouts/hass-tabs-subpage";
import { haStyle } from "../../../src/resources/styles"; import { haStyle } from "../../../src/resources/styles";
import { HomeAssistant, Route } from "../../../src/types"; import { HomeAssistant, Route } from "../../../src/types";
import { hassioStyle } from "../resources/hassio-style"; import { hassioStyle } from "../resources/hassio-style";
import "./config/hassio-addon-audio"; import "./config/hassio-addon-audio";
import "./config/hassio-addon-config"; import "./config/hassio-addon-config";
import "./config/hassio-addon-network";
import "./hassio-addon-router";
import "./info/hassio-addon-info"; import "./info/hassio-addon-info";
import "./log/hassio-addon-logs"; import "./log/hassio-addon-logs";
import "./config/hassio-addon-network";
import type { PageNavigation } from "../../../src/layouts/hass-tabs-subpage";
import "../../../src/layouts/hass-tabs-subpage";
import "./hassio-addon-router";
@customElement("hassio-addon-dashboard") @customElement("hassio-addon-dashboard")
class HassioAddonDashboard extends LitElement { class HassioAddonDashboard extends LitElement {
@@ -59,7 +63,7 @@ class HassioAddonDashboard extends LitElement {
{ {
name: "Info", name: "Info",
path: `/hassio/addon/${this.addon.slug}/info`, path: `/hassio/addon/${this.addon.slug}/info`,
icon: "hassio:information-variant", iconPath: mdiInformationVariant,
}, },
]; ];
@@ -67,7 +71,7 @@ class HassioAddonDashboard extends LitElement {
addonTabs.push({ addonTabs.push({
name: "Documentation", name: "Documentation",
path: `/hassio/addon/${this.addon.slug}/documentation`, path: `/hassio/addon/${this.addon.slug}/documentation`,
icon: "hassio:file-document", iconPath: mdiFileDocument,
}); });
} }
@@ -76,12 +80,12 @@ class HassioAddonDashboard extends LitElement {
{ {
name: "Configuration", name: "Configuration",
path: `/hassio/addon/${this.addon.slug}/config`, path: `/hassio/addon/${this.addon.slug}/config`,
icon: "hassio:cogs", iconPath: mdiCogs,
}, },
{ {
name: "Log", name: "Log",
path: `/hassio/addon/${this.addon.slug}/logs`, path: `/hassio/addon/${this.addon.slug}/logs`,
icon: "hassio:math-log", iconPath: mdiMathLog,
} }
); );
} }
@@ -115,7 +119,6 @@ class HassioAddonDashboard extends LitElement {
css` css`
:host { :host {
color: var(--primary-text-color); color: var(--primary-text-color);
--paper-card-header-color: var(--primary-text-color);
} }
.content { .content {
padding: 24px 0 32px; padding: 24px 0 32px;

View File

@@ -1,15 +1,15 @@
import { customElement, property } from "lit-element";
import { HassioAddonDetails } from "../../../src/data/hassio/addon";
import { import {
HassRouterPage, HassRouterPage,
RouterOptions, RouterOptions,
} from "../../../src/layouts/hass-router-page"; } from "../../../src/layouts/hass-router-page";
import { customElement, property } from "lit-element";
import { HomeAssistant } from "../../../src/types"; import { HomeAssistant } from "../../../src/types";
import "./config/hassio-addon-config-tab";
import "./documentation/hassio-addon-documentation-tab";
// Don't codesplit the others, because it breaks the UI when pushed to a Pi // Don't codesplit the others, because it breaks the UI when pushed to a Pi
import "./info/hassio-addon-info-tab"; import "./info/hassio-addon-info-tab";
import "./config/hassio-addon-config-tab";
import "./log/hassio-addon-log-tab"; import "./log/hassio-addon-log-tab";
import "./documentation/hassio-addon-documentation-tab";
import { HassioAddonDetails } from "../../../src/data/hassio/addon";
@customElement("hassio-addon-router") @customElement("hassio-addon-router")
class HassioAddonRouter extends HassRouterPage { class HassioAddonRouter extends HassRouterPage {

View File

@@ -8,12 +8,10 @@ import {
property, property,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { HomeAssistant } from "../../../../src/types";
import { HassioAddonDetails } from "../../../../src/data/hassio/addon"; import { HassioAddonDetails } from "../../../../src/data/hassio/addon";
import { hassioStyle } from "../../resources/hassio-style";
import { haStyle } from "../../../../src/resources/styles"; import { haStyle } from "../../../../src/resources/styles";
import { HomeAssistant } from "../../../../src/types";
import { hassioStyle } from "../../resources/hassio-style";
import "./hassio-addon-info"; import "./hassio-addon-info";
@customElement("hassio-addon-info-tab") @customElement("hassio-addon-info-tab")

View File

@@ -1,5 +1,20 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/paper-card/paper-card"; import {
mdiArrowUpBoldCircle,
mdiCheckCircle,
mdiChip,
mdiCircle,
mdiCursorDefaultClickOutline,
mdiDocker,
mdiExclamationThick,
mdiFlask,
mdiHomeAssistant,
mdiInformation,
mdiKey,
mdiNetwork,
mdiPound,
mdiShield,
} from "@mdi/js";
import "@polymer/paper-tooltip/paper-tooltip"; import "@polymer/paper-tooltip/paper-tooltip";
import { import {
css, css,
@@ -16,10 +31,11 @@ import { fireEvent } from "../../../../src/common/dom/fire_event";
import { navigate } from "../../../../src/common/navigate"; import { navigate } from "../../../../src/common/navigate";
import "../../../../src/components/buttons/ha-call-api-button"; import "../../../../src/components/buttons/ha-call-api-button";
import "../../../../src/components/buttons/ha-progress-button"; import "../../../../src/components/buttons/ha-progress-button";
import "../../../../src/components/ha-card";
import "../../../../src/components/ha-label-badge"; import "../../../../src/components/ha-label-badge";
import "../../../../src/components/ha-markdown"; import "../../../../src/components/ha-markdown";
import "../../../../src/components/ha-svg-icon";
import "../../../../src/components/ha-switch"; import "../../../../src/components/ha-switch";
import "../../../../src/components/ha-icon";
import { import {
fetchHassioAddonChangelog, fetchHassioAddonChangelog,
HassioAddonDetails, HassioAddonDetails,
@@ -30,23 +46,23 @@ import {
setHassioAddonSecurity, setHassioAddonSecurity,
uninstallHassioAddon, uninstallHassioAddon,
} from "../../../../src/data/hassio/addon"; } from "../../../../src/data/hassio/addon";
import { showConfirmationDialog } from "../../../../src/dialogs/generic/show-dialog-box";
import { haStyle } from "../../../../src/resources/styles"; import { haStyle } from "../../../../src/resources/styles";
import { HomeAssistant } from "../../../../src/types"; import { HomeAssistant } from "../../../../src/types";
import "../../components/hassio-card-content"; import "../../components/hassio-card-content";
import { showHassioMarkdownDialog } from "../../dialogs/markdown/show-dialog-hassio-markdown"; import { showHassioMarkdownDialog } from "../../dialogs/markdown/show-dialog-hassio-markdown";
import { hassioStyle } from "../../resources/hassio-style"; import { hassioStyle } from "../../resources/hassio-style";
import { showConfirmationDialog } from "../../../../src/dialogs/generic/show-dialog-box";
const STAGE_ICON = { const STAGE_ICON = {
stable: "mdi:check-circle", stable: mdiCheckCircle,
experimental: "mdi:flask", experimental: mdiFlask,
deprecated: "mdi:exclamation-thick", deprecated: mdiExclamationThick,
}; };
const PERMIS_DESC = { const PERMIS_DESC = {
stage: { stage: {
title: "Add-on Stage", title: "Add-on Stage",
description: `Add-ons can have one of three stages:\n\n<ha-icon icon='${STAGE_ICON.stable}'></ha-icon>**Stable**: These are add-ons ready to be used in production.\n<ha-icon icon='${STAGE_ICON.experimental}'></ha-icon>**Experimental**: These may contain bugs, and may be unfinished.\n<ha-icon icon='${STAGE_ICON.deprecated}'></ha-icon>**Deprecated**: These add-ons will no longer receive any updates.`, description: `Add-ons can have one of three stages:\n\n<ha-svg-icon path='${STAGE_ICON.stable}'></ha-svg-icon> **Stable**: These are add-ons ready to be used in production.\n\n<ha-svg-icon path='${STAGE_ICON.experimental}'></ha-svg-icon> **Experimental**: These may contain bugs, and may be unfinished.\n\n<ha-svg-icon path='${STAGE_ICON.deprecated}'></ha-svg-icon> **Deprecated**: These add-ons will no longer receive any updates.`,
}, },
rating: { rating: {
title: "Add-on Security Rating", title: "Add-on Security Rating",
@@ -116,7 +132,7 @@ class HassioAddonInfo extends LitElement {
return html` return html`
${this._computeUpdateAvailable ${this._computeUpdateAvailable
? html` ? html`
<paper-card heading="Update available! 🎉"> <ha-card header="Update available! 🎉">
<div class="card-content"> <div class="card-content">
<hassio-card-content <hassio-card-content
.hass=${this.hass} .hass=${this.hass}
@@ -124,7 +140,7 @@ class HassioAddonInfo extends LitElement {
.version_latest} is available" .version_latest} is available"
.description="You are currently running version ${this.addon .description="You are currently running version ${this.addon
.version}" .version}"
icon="hassio:arrow-up-bold-circle" icon=${mdiArrowUpBoldCircle}
iconClass="update" iconClass="update"
></hassio-card-content> ></hassio-card-content>
${!this.addon.available ${!this.addon.available
@@ -151,12 +167,13 @@ class HassioAddonInfo extends LitElement {
` `
: ""} : ""}
</div> </div>
</paper-card> </ha-card>
` `
: ""} : ""}
${!this.addon.protected ${!this.addon.protected
? html` ? html`
<paper-card heading="Warning: Protection mode is disabled!" class="warning"> <ha-card class="warning">
<div class="card-header">Warning: Protection mode is disabled!</div>
<div class="card-content"> <div class="card-content">
Protection mode on this add-on is disabled! This gives the add-on full access to the entire system, which adds security risks, and could damage your system when used incorrectly. Only disable the protection mode if you know, need AND trust the source of this add-on. Protection mode on this add-on is disabled! This gives the add-on full access to the entire system, which adds security risks, and could damage your system when used incorrectly. Only disable the protection mode if you know, need AND trust the source of this add-on.
</div> </div>
@@ -164,11 +181,11 @@ class HassioAddonInfo extends LitElement {
<mwc-button @click=${this._protectionToggled}>Enable Protection mode</mwc-button> <mwc-button @click=${this._protectionToggled}>Enable Protection mode</mwc-button>
</div> </div>
</div> </div>
</paper-card> </ha-card>
` `
: ""} : ""}
<paper-card> <ha-card>
<div class="card-content"> <div class="card-content">
<div class="addon-header"> <div class="addon-header">
${!this.narrow ? this.addon.name : ""} ${!this.narrow ? this.addon.name : ""}
@@ -177,18 +194,18 @@ class HassioAddonInfo extends LitElement {
? html` ? html`
${this._computeIsRunning ${this._computeIsRunning
? html` ? html`
<ha-icon <ha-svg-icon
title="Add-on is running" title="Add-on is running"
class="running" class="running"
icon="hassio:circle" path=${mdiCircle}
></ha-icon> ></ha-svg-icon>
` `
: html` : html`
<ha-icon <ha-svg-icon
title="Add-on is stopped" title="Add-on is stopped"
class="stopped" class="stopped"
icon="hassio:circle" path=${mdiCircle}
></ha-icon> ></ha-svg-icon>
`} `}
` `
: html` ${this.addon.version_latest} `} : html` ${this.addon.version_latest} `}
@@ -232,10 +249,11 @@ class HassioAddonInfo extends LitElement {
})} })}
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
id="stage" id="stage"
.icon=${STAGE_ICON[this.addon.stage]}
label="stage" label="stage"
description="" description=""
></ha-label-badge> >
<ha-svg-icon .path=${STAGE_ICON[this.addon.stage]}></ha-svg-icon>
</ha-label-badge>
<ha-label-badge <ha-label-badge
class=${classMap({ class=${classMap({
green: [5, 6].includes(Number(this.addon.rating)), green: [5, 6].includes(Number(this.addon.rating)),
@@ -253,10 +271,11 @@ class HassioAddonInfo extends LitElement {
<ha-label-badge <ha-label-badge
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
id="host_network" id="host_network"
icon="hassio:network"
label="host" label="host"
description="" description=""
></ha-label-badge> >
<ha-svg-icon path=${mdiNetwork}></ha-svg-icon>
</ha-label-badge>
` `
: ""} : ""}
${this.addon.full_access ${this.addon.full_access
@@ -264,10 +283,11 @@ class HassioAddonInfo extends LitElement {
<ha-label-badge <ha-label-badge
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
id="full_access" id="full_access"
icon="hassio:chip"
label="hardware" label="hardware"
description="" description=""
></ha-label-badge> >
<ha-svg-icon path=${mdiChip}></ha-svg-icon>
</ha-label-badge>
` `
: ""} : ""}
${this.addon.homeassistant_api ${this.addon.homeassistant_api
@@ -275,10 +295,11 @@ class HassioAddonInfo extends LitElement {
<ha-label-badge <ha-label-badge
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
id="homeassistant_api" id="homeassistant_api"
icon="hassio:home-assistant"
label="hass" label="hass"
description="" description=""
></ha-label-badge> >
<ha-svg-icon path=${mdiHomeAssistant}></ha-svg-icon>
</ha-label-badge>
` `
: ""} : ""}
${this._computeHassioApi ${this._computeHassioApi
@@ -286,10 +307,11 @@ class HassioAddonInfo extends LitElement {
<ha-label-badge <ha-label-badge
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
id="hassio_api" id="hassio_api"
icon="hassio:home-assistant"
label="hassio" label="hassio"
.description=${this.addon.hassio_role} .description=${this.addon.hassio_role}
></ha-label-badge> >
<ha-svg-icon path=${mdiHomeAssistant}></ha-svg-icon>
</ha-label-badge>
` `
: ""} : ""}
${this.addon.docker_api ${this.addon.docker_api
@@ -297,10 +319,11 @@ class HassioAddonInfo extends LitElement {
<ha-label-badge <ha-label-badge
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
id="docker_api" id="docker_api"
icon="hassio:docker"
label="docker" label="docker"
description="" description=""
></ha-label-badge> >
<ha-svg-icon path=${mdiDocker}></ha-svg-icon>
</ha-label-badge>
` `
: ""} : ""}
${this.addon.host_pid ${this.addon.host_pid
@@ -308,10 +331,11 @@ class HassioAddonInfo extends LitElement {
<ha-label-badge <ha-label-badge
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
id="host_pid" id="host_pid"
icon="hassio:pound"
label="host pid" label="host pid"
description="" description=""
></ha-label-badge> >
<ha-svg-icon path=${mdiPound}></ha-svg-icon>
</ha-label-badge>
` `
: ""} : ""}
${this.addon.apparmor ${this.addon.apparmor
@@ -320,10 +344,11 @@ class HassioAddonInfo extends LitElement {
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
class=${this._computeApparmorClassName} class=${this._computeApparmorClassName}
id="apparmor" id="apparmor"
icon="hassio:shield"
label="apparmor" label="apparmor"
description="" description=""
></ha-label-badge> >
<ha-svg-icon path=${mdiShield}></ha-svg-icon>
</ha-label-badge>
` `
: ""} : ""}
${this.addon.auth_api ${this.addon.auth_api
@@ -331,10 +356,11 @@ class HassioAddonInfo extends LitElement {
<ha-label-badge <ha-label-badge
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
id="auth_api" id="auth_api"
icon="hassio:key"
label="auth" label="auth"
description="" description=""
></ha-label-badge> >
<ha-svg-icon path=${mdiKey}></ha-svg-icon>
</ha-label-badge>
` `
: ""} : ""}
${this.addon.ingress ${this.addon.ingress
@@ -342,10 +368,13 @@ class HassioAddonInfo extends LitElement {
<ha-label-badge <ha-label-badge
@click=${this._showMoreInfo} @click=${this._showMoreInfo}
id="ingress" id="ingress"
icon="hassio:cursor-default-click-outline"
label="ingress" label="ingress"
description="" description=""
></ha-label-badge> >
<ha-svg-icon
path=${mdiCursorDefaultClickOutline}
></ha-svg-icon>
</ha-label-badge>
` `
: ""} : ""}
</div> </div>
@@ -399,7 +428,7 @@ class HassioAddonInfo extends LitElement {
<div> <div>
Protection mode Protection mode
<span> <span>
<ha-icon icon="hassio:information"></ha-icon> <ha-svg-icon path=${mdiInformation}></ha-svg-icon>
<paper-tooltip> <paper-tooltip>
Grant the add-on elevated system access. Grant the add-on elevated system access.
</paper-tooltip> </paper-tooltip>
@@ -502,17 +531,17 @@ class HassioAddonInfo extends LitElement {
</ha-progress-button> </ha-progress-button>
`} `}
</div> </div>
</paper-card> </ha-card>
${this.addon.long_description ${this.addon.long_description
? html` ? html`
<paper-card> <ha-card>
<div class="card-content"> <div class="card-content">
<ha-markdown <ha-markdown
.content=${this.addon.long_description} .content=${this.addon.long_description}
></ha-markdown> ></ha-markdown>
</div> </div>
</paper-card> </ha-card>
` `
: ""} : ""}
`; `;
@@ -526,16 +555,21 @@ class HassioAddonInfo extends LitElement {
:host { :host {
display: block; display: block;
} }
paper-card { ha-card {
display: block; display: block;
margin-bottom: 16px; margin-bottom: 16px;
} }
paper-card.warning { ha-card.warning {
background-color: var(--google-red-500); background-color: var(--google-red-500);
color: white; color: white;
--paper-card-header-color: white;
} }
paper-card.warning mwc-button { ha-card.warning .card-header {
color: white;
}
ha-card.warning .card-content {
color: white;
}
ha-card.warning mwc-button {
--mdc-theme-primary: white !important; --mdc-theme-primary: white !important;
} }
.warning { .warning {
@@ -548,7 +582,7 @@ class HassioAddonInfo extends LitElement {
.addon-header { .addon-header {
padding-left: 8px; padding-left: 8px;
font-size: 24px; font-size: 24px;
color: var(--paper-card-header-color, --primary-text-color); color: var(--ha-card-header-color, --primary-text-color);
} }
.addon-version { .addon-version {
float: right; float: right;
@@ -575,7 +609,7 @@ class HassioAddonInfo extends LitElement {
width: 180px; width: 180px;
display: inline-block; display: inline-block;
} }
.state ha-icon { .state ha-svg-icon {
width: 16px; width: 16px;
height: 16px; height: 16px;
color: var(--secondary-text-color); color: var(--secondary-text-color);
@@ -583,10 +617,10 @@ class HassioAddonInfo extends LitElement {
ha-switch { ha-switch {
display: flex; display: flex;
} }
ha-icon.running { ha-svg-icon.running {
color: var(--paper-green-400); color: var(--paper-green-400);
} }
ha-icon.stopped { ha-svg-icon.stopped {
color: var(--google-red-300); color: var(--google-red-300);
} }
ha-call-api-button { ha-call-api-button {
@@ -664,7 +698,7 @@ class HassioAddonInfo extends LitElement {
} }
private _showMoreInfo(ev): void { private _showMoreInfo(ev): void {
const id = ev.target.getAttribute("id"); const id = ev.currentTarget.id;
showHassioMarkdownDialog(this, { showHassioMarkdownDialog(this, {
title: PERMIS_DESC[id].title, title: PERMIS_DESC[id].title,
content: PERMIS_DESC[id].description, content: PERMIS_DESC[id].description,

View File

@@ -1,5 +1,4 @@
import "@polymer/paper-spinner/paper-spinner-lite"; import "@polymer/paper-spinner/paper-spinner-lite";
import { import {
css, css,
CSSResult, CSSResult,
@@ -9,12 +8,10 @@ import {
property, property,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { HomeAssistant } from "../../../../src/types";
import { HassioAddonDetails } from "../../../../src/data/hassio/addon"; import { HassioAddonDetails } from "../../../../src/data/hassio/addon";
import { hassioStyle } from "../../resources/hassio-style";
import { haStyle } from "../../../../src/resources/styles"; import { haStyle } from "../../../../src/resources/styles";
import { HomeAssistant } from "../../../../src/types";
import { hassioStyle } from "../../resources/hassio-style";
import "./hassio-addon-logs"; import "./hassio-addon-logs";
@customElement("hassio-addon-log-tab") @customElement("hassio-addon-log-tab")

View File

@@ -1,5 +1,4 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/paper-card/paper-card";
import { import {
css, css,
CSSResult, CSSResult,
@@ -9,6 +8,7 @@ import {
property, property,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import "../../../../src/components/ha-card";
import { import {
fetchHassioAddonLogs, fetchHassioAddonLogs,
HassioAddonDetails, HassioAddonDetails,
@@ -36,7 +36,7 @@ class HassioAddonLogs extends LitElement {
protected render(): TemplateResult { protected render(): TemplateResult {
return html` return html`
<h1>${this.addon.name}</h1> <h1>${this.addon.name}</h1>
<paper-card> <ha-card>
${this._error ? html` <div class="errors">${this._error}</div> ` : ""} ${this._error ? html` <div class="errors">${this._error}</div> ` : ""}
<div class="card-content"> <div class="card-content">
${this._content ${this._content
@@ -48,7 +48,7 @@ class HassioAddonLogs extends LitElement {
<div class="card-actions"> <div class="card-actions">
<mwc-button @click=${this._refresh}>Refresh</mwc-button> <mwc-button @click=${this._refresh}>Refresh</mwc-button>
</div> </div>
</paper-card> </ha-card>
`; `;
} }
@@ -58,7 +58,7 @@ class HassioAddonLogs extends LitElement {
hassioStyle, hassioStyle,
css` css`
:host, :host,
paper-card { ha-card {
display: block; display: block;
} }
.errors { .errors {

View File

@@ -1,3 +1,4 @@
import { mdiHelpCircle } from "@mdi/js";
import { import {
css, css,
CSSResult, CSSResult,
@@ -8,7 +9,7 @@ import {
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import "../../../src/components/ha-relative-time"; import "../../../src/components/ha-relative-time";
import "../../../src/components/ha-icon"; import "../../../src/components/ha-svg-icon";
import { HomeAssistant } from "../../../src/types"; import { HomeAssistant } from "../../../src/types";
@customElement("hassio-card-content") @customElement("hassio-card-content")
@@ -31,7 +32,7 @@ class HassioCardContent extends LitElement {
@property() public iconClass?: string; @property() public iconClass?: string;
@property() public icon = "hass:help-circle"; @property() public icon = mdiHelpCircle;
@property() public iconImage?: string; @property() public iconImage?: string;
@@ -48,11 +49,11 @@ class HassioCardContent extends LitElement {
</div> </div>
` `
: html` : html`
<ha-icon <ha-svg-icon
class=${this.iconClass} class=${this.iconClass}
.icon=${this.icon} .path=${this.icon}
.title=${this.iconTitle} .title=${this.iconTitle}
></ha-icon> ></ha-svg-icon>
`} `}
<div> <div>
<div class="title"> <div class="title">
@@ -78,25 +79,25 @@ class HassioCardContent extends LitElement {
static get styles(): CSSResult { static get styles(): CSSResult {
return css` return css`
ha-icon { ha-svg-icon {
margin-right: 24px; margin-right: 24px;
margin-left: 8px; margin-left: 8px;
margin-top: 12px; margin-top: 12px;
float: left; float: left;
color: var(--secondary-text-color); color: var(--secondary-text-color);
} }
ha-icon.update { ha-svg-icon.update {
color: var(--paper-orange-400); color: var(--paper-orange-400);
} }
ha-icon.running, ha-svg-icon.running,
ha-icon.installed { ha-svg-icon.installed {
color: var(--paper-green-400); color: var(--paper-green-400);
} }
ha-icon.hassupdate, ha-svg-icon.hassupdate,
ha-icon.snapshot { ha-svg-icon.snapshot {
color: var(--paper-item-icon-color); color: var(--paper-item-icon-color);
} }
ha-icon.not_available { ha-svg-icon.not_available {
color: var(--google-red-500); color: var(--google-red-500);
} }
.title { .title {

View File

@@ -1,4 +1,4 @@
import "@polymer/paper-card/paper-card"; import { mdiArrowUpBoldCircle, mdiPuzzle } from "@mdi/js";
import { import {
css, css,
CSSResult, CSSResult,
@@ -10,6 +10,7 @@ import {
} from "lit-element"; } from "lit-element";
import { atLeastVersion } from "../../../src/common/config/version"; import { atLeastVersion } from "../../../src/common/config/version";
import { navigate } from "../../../src/common/navigate"; import { navigate } from "../../../src/common/navigate";
import "../../../src/components/ha-card";
import { HassioAddonInfo } from "../../../src/data/hassio/addon"; import { HassioAddonInfo } from "../../../src/data/hassio/addon";
import { haStyle } from "../../../src/resources/styles"; import { haStyle } from "../../../src/resources/styles";
import { HomeAssistant } from "../../../src/types"; import { HomeAssistant } from "../../../src/types";
@@ -29,19 +30,19 @@ class HassioAddons extends LitElement {
<div class="card-group"> <div class="card-group">
${!this.addons ${!this.addons
? html` ? html`
<paper-card> <ha-card>
<div class="card-content"> <div class="card-content">
You don't have any add-ons installed yet. Head over to You don't have any add-ons installed yet. Head over to
<a href="#" @click=${this._openStore}>the add-on store</a> <a href="#" @click=${this._openStore}>the add-on store</a>
to get started! to get started!
</div> </div>
</paper-card> </ha-card>
` `
: this.addons : this.addons
.sort((a, b) => (a.name > b.name ? 1 : -1)) .sort((a, b) => (a.name > b.name ? 1 : -1))
.map( .map(
(addon) => html` (addon) => html`
<paper-card .addon=${addon} @click=${this._addonTapped}> <ha-card .addon=${addon} @click=${this._addonTapped}>
<div class="card-content"> <div class="card-content">
<hassio-card-content <hassio-card-content
.hass=${this.hass} .hass=${this.hass}
@@ -51,8 +52,8 @@ class HassioAddons extends LitElement {
.showTopbar=${addon.installed !== addon.version} .showTopbar=${addon.installed !== addon.version}
topbarClass="update" topbarClass="update"
.icon=${addon.installed !== addon.version .icon=${addon.installed !== addon.version
? "hassio:arrow-up-bold-circle" ? mdiArrowUpBoldCircle
: "hassio:puzzle"} : mdiPuzzle}
.iconTitle=${addon.state !== "started" .iconTitle=${addon.state !== "started"
? "Add-on is stopped" ? "Add-on is stopped"
: addon.installed !== addon.version : addon.installed !== addon.version
@@ -75,7 +76,7 @@ class HassioAddons extends LitElement {
: undefined} : undefined}
></hassio-card-content> ></hassio-card-content>
</div> </div>
</paper-card> </ha-card>
` `
)} )}
</div> </div>
@@ -88,7 +89,7 @@ class HassioAddons extends LitElement {
haStyle, haStyle,
hassioStyle, hassioStyle,
css` css`
paper-card { ha-card {
cursor: pointer; cursor: pointer;
} }
`, `,

View File

@@ -12,14 +12,13 @@ import {
HassioHomeAssistantInfo, HassioHomeAssistantInfo,
HassioSupervisorInfo, HassioSupervisorInfo,
} from "../../../src/data/hassio/supervisor"; } from "../../../src/data/hassio/supervisor";
import "../../../src/layouts/hass-tabs-subpage";
import { haStyle } from "../../../src/resources/styles"; import { haStyle } from "../../../src/resources/styles";
import { HomeAssistant, Route } from "../../../src/types"; import { HomeAssistant, Route } from "../../../src/types";
import "../../../src/layouts/hass-tabs-subpage"; import { supervisorTabs } from "../hassio-panel";
import "./hassio-addons"; import "./hassio-addons";
import "./hassio-update"; import "./hassio-update";
import { supervisorTabs } from "../hassio-panel";
@customElement("hassio-dashboard") @customElement("hassio-dashboard")
class HassioDashboard extends LitElement { class HassioDashboard extends LitElement {
@property({ attribute: false }) public hass!: HomeAssistant; @property({ attribute: false }) public hass!: HomeAssistant;

View File

@@ -1,5 +1,5 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/paper-card/paper-card"; import { mdiHomeAssistant } from "@mdi/js";
import { import {
css, css,
CSSResult, CSSResult,
@@ -10,15 +10,15 @@ import {
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import "../../../src/components/buttons/ha-call-api-button"; import "../../../src/components/buttons/ha-call-api-button";
import "../../../src/components/ha-card";
import "../../../src/components/ha-svg-icon";
import { HassioHassOSInfo } from "../../../src/data/hassio/host"; import { HassioHassOSInfo } from "../../../src/data/hassio/host";
import { import {
HassioHomeAssistantInfo, HassioHomeAssistantInfo,
HassioSupervisorInfo, HassioSupervisorInfo,
} from "../../../src/data/hassio/supervisor"; } from "../../../src/data/hassio/supervisor";
import { haStyle } from "../../../src/resources/styles"; import { haStyle } from "../../../src/resources/styles";
import "../../../src/components/ha-icon";
import { HomeAssistant } from "../../../src/types"; import { HomeAssistant } from "../../../src/types";
import "../components/hassio-card-content";
import { hassioStyle } from "../resources/hassio-style"; import { hassioStyle } from "../resources/hassio-style";
@customElement("hassio-update") @customElement("hassio-update")
@@ -72,7 +72,7 @@ export class HassioUpdate extends LitElement {
`https://${ `https://${
this.hassInfo.version_latest.includes("b") ? "rc" : "www" this.hassInfo.version_latest.includes("b") ? "rc" : "www"
}.home-assistant.io/latest-release-notes/`, }.home-assistant.io/latest-release-notes/`,
"hassio:home-assistant" mdiHomeAssistant
)} )}
${this._renderUpdateCard( ${this._renderUpdateCard(
"Supervisor", "Supervisor",
@@ -107,12 +107,12 @@ export class HassioUpdate extends LitElement {
return html``; return html``;
} }
return html` return html`
<paper-card> <ha-card>
<div class="card-content"> <div class="card-content">
${icon ${icon
? html` ? html`
<div class="icon"> <div class="icon">
<ha-icon .icon=${icon}></ha-icon> <ha-svg-icon .path=${icon}></ha-svg-icon>
</div> </div>
` `
: ""} : ""}
@@ -133,7 +133,7 @@ export class HassioUpdate extends LitElement {
Update Update
</ha-call-api-button> </ha-call-api-button>
</div> </div>
</paper-card> </ha-card>
`; `;
} }

View File

@@ -1,7 +1,3 @@
import "@polymer/app-layout/app-toolbar/app-toolbar";
import { PaperDialogElement } from "@polymer/paper-dialog";
import "@polymer/paper-dialog-scrollable/paper-dialog-scrollable";
import "../../../../src/components/ha-icon-button";
import { import {
css, css,
CSSResult, CSSResult,
@@ -9,46 +5,50 @@ import {
html, html,
LitElement, LitElement,
property, property,
query,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import "../../../../src/components/dialog/ha-paper-dialog"; import { createCloseHeading } from "../../../../src/components/ha-dialog";
import "../../../../src/components/ha-markdown"; import "../../../../src/components/ha-markdown";
import { haStyleDialog } from "../../../../src/resources/styles"; import { haStyleDialog } from "../../../../src/resources/styles";
import { HomeAssistant } from "../../../../src/types";
import { hassioStyle } from "../../resources/hassio-style"; import { hassioStyle } from "../../resources/hassio-style";
import { HassioMarkdownDialogParams } from "./show-dialog-hassio-markdown"; import { HassioMarkdownDialogParams } from "./show-dialog-hassio-markdown";
@customElement("dialog-hassio-markdown") @customElement("dialog-hassio-markdown")
class HassioMarkdownDialog extends LitElement { class HassioMarkdownDialog extends LitElement {
@property() public hass!: HomeAssistant;
@property() public title!: string; @property() public title!: string;
@property() public content!: string; @property() public content!: string;
@query("#dialog") private _dialog!: PaperDialogElement; @property() private _opened = false;
public showDialog(params: HassioMarkdownDialogParams) { public showDialog(params: HassioMarkdownDialogParams) {
this.title = params.title; this.title = params.title;
this.content = params.content; this.content = params.content;
this._dialog.open(); this._opened = true;
} }
protected render(): TemplateResult { protected render(): TemplateResult {
if (!this._opened) {
return html``;
}
return html` return html`
<ha-paper-dialog id="dialog" with-backdrop=""> <ha-dialog
<app-toolbar> open
<ha-icon-button @closing=${this._closeDialog}
icon="hassio:close" .heading=${createCloseHeading(this.hass, this.title)}
dialog-dismiss="" >
></ha-icon-button> <ha-markdown .content=${this.content || ""}></ha-markdown>
<div main-title="">${this.title}</div> </ha-dialog>
</app-toolbar>
<paper-dialog-scrollable>
<ha-markdown .content=${this.content || ""}></ha-markdown>
</paper-dialog-scrollable>
</ha-paper-dialog>
`; `;
} }
private _closeDialog(): void {
this._opened = false;
}
static get styles(): CSSResult[] { static get styles(): CSSResult[] {
return [ return [
haStyleDialog, haStyleDialog,

View File

@@ -1,9 +1,11 @@
import "@material/mwc-button/mwc-button"; import "@material/mwc-button/mwc-button";
import "@material/mwc-icon-button/mwc-icon-button";
import { mdiDelete } from "@mdi/js";
import "@polymer/paper-input/paper-input"; import "@polymer/paper-input/paper-input";
import "@polymer/paper-spinner/paper-spinner";
import type { PaperInputElement } from "@polymer/paper-input/paper-input"; import type { PaperInputElement } from "@polymer/paper-input/paper-input";
import "@polymer/paper-item/paper-item"; import "@polymer/paper-item/paper-item";
import "@polymer/paper-item/paper-item-body"; import "@polymer/paper-item/paper-item-body";
import "@polymer/paper-spinner/paper-spinner";
import { import {
css, css,
CSSResult, CSSResult,
@@ -16,16 +18,14 @@ import {
} from "lit-element"; } from "lit-element";
import memoizeOne from "memoize-one"; import memoizeOne from "memoize-one";
import "../../../../src/components/ha-dialog"; import "../../../../src/components/ha-dialog";
import "../../../../src/components/ha-icon-button"; import "../../../../src/components/ha-svg-icon";
import {
fetchHassioAddonsInfo,
HassioAddonRepository,
} from "../../../../src/data/hassio/addon";
import { setSupervisorOption } from "../../../../src/data/hassio/supervisor";
import { haStyle, haStyleDialog } from "../../../../src/resources/styles"; import { haStyle, haStyleDialog } from "../../../../src/resources/styles";
import type { HomeAssistant } from "../../../../src/types"; import type { HomeAssistant } from "../../../../src/types";
import {
HassioAddonRepository,
fetchHassioAddonsInfo,
} from "../../../../src/data/hassio/addon";
import { setSupervisorOption } from "../../../../src/data/hassio/supervisor";
import { HassioRepositoryDialogParams } from "./show-dialog-repositories"; import { HassioRepositoryDialogParams } from "./show-dialog-repositories";
@customElement("dialog-hassio-repositories") @customElement("dialog-hassio-repositories")
@@ -84,12 +84,13 @@ class HassioRepositoriesDialog extends LitElement {
<div secondary>${repo.maintainer}</div> <div secondary>${repo.maintainer}</div>
<div secondary>${repo.url}</div> <div secondary>${repo.url}</div>
</paper-item-body> </paper-item-body>
<ha-icon-button <mwc-icon-button
.slug=${repo.slug} .slug=${repo.slug}
title="Remove" title="Remove"
@click=${this._removeRepository} @click=${this._removeRepository}
icon="hassio:delete" >
></ha-icon-button> <ha-svg-icon path=${mdiDelete}></ha-svg-icon>
</mwc-icon-button>
</paper-item> </paper-item>
`; `;
}) })
@@ -194,7 +195,7 @@ class HassioRepositoriesDialog extends LitElement {
} }
private async _removeRepository(ev: Event) { private async _removeRepository(ev: Event) {
const slug = (ev.target as any).slug; const slug = (ev.currentTarget as any).slug;
const repositories = this._filteredRepositories(this._repos); const repositories = this._filteredRepositories(this._repos);
const repository = repositories.find((repo) => { const repository = repositories.find((repo) => {
return repo.slug === slug; return repo.slug === slug;

View File

@@ -1,6 +1,6 @@
import { fireEvent } from "../../../../src/common/dom/fire_event"; import { fireEvent } from "../../../../src/common/dom/fire_event";
import "./dialog-hassio-repositories";
import { HassioAddonRepository } from "../../../../src/data/hassio/addon"; import { HassioAddonRepository } from "../../../../src/data/hassio/addon";
import "./dialog-hassio-repositories";
export interface HassioRepositoryDialogParams { export interface HassioRepositoryDialogParams {
repos: HassioAddonRepository[]; repos: HassioAddonRepository[];

View File

@@ -1,10 +1,6 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/app-layout/app-toolbar/app-toolbar"; import { mdiDelete, mdiDownload, mdiHistory } from "@mdi/js";
import { PaperCheckboxElement } from "@polymer/paper-checkbox/paper-checkbox"; import { PaperCheckboxElement } from "@polymer/paper-checkbox/paper-checkbox";
import { PaperDialogElement } from "@polymer/paper-dialog";
import "@polymer/paper-dialog-scrollable/paper-dialog-scrollable";
import "../../../../src/components/ha-icon-button";
import "../../../../src/components/ha-icon";
import "@polymer/paper-input/paper-input"; import "@polymer/paper-input/paper-input";
import { import {
css, css,
@@ -13,10 +9,10 @@ import {
html, html,
LitElement, LitElement,
property, property,
query,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import "../../../../src/components/dialog/ha-paper-dialog"; import { createCloseHeading } from "../../../../src/components/ha-dialog";
import "../../../../src/components/ha-svg-icon";
import { getSignedPath } from "../../../../src/data/auth"; import { getSignedPath } from "../../../../src/data/auth";
import { import {
fetchHassioSnapshotInfo, fetchHassioSnapshotInfo,
@@ -76,7 +72,7 @@ class HassioSnapshotDialog extends LitElement {
@property() private _error?: string; @property() private _error?: string;
@property() private snapshot?: HassioSnapshotDetail; @property() private _snapshot?: HassioSnapshotDetail;
@property() private _folders!: FolderItem[]; @property() private _folders!: FolderItem[];
@@ -88,49 +84,35 @@ class HassioSnapshotDialog extends LitElement {
@property() private _restoreHass: boolean | null | undefined = true; @property() private _restoreHass: boolean | null | undefined = true;
@query("#dialog") private _dialog!: PaperDialogElement;
public async showDialog(params: HassioSnapshotDialogParams) { public async showDialog(params: HassioSnapshotDialogParams) {
this.snapshot = await fetchHassioSnapshotInfo(this.hass, params.slug); this._snapshot = await fetchHassioSnapshotInfo(this.hass, params.slug);
this._folders = _computeFolders( this._folders = _computeFolders(
this.snapshot.folders this._snapshot.folders
).sort((a: FolderItem, b: FolderItem) => (a.name > b.name ? 1 : -1)); ).sort((a: FolderItem, b: FolderItem) => (a.name > b.name ? 1 : -1));
this._addons = _computeAddons( this._addons = _computeAddons(
this.snapshot.addons this._snapshot.addons
).sort((a: AddonItem, b: AddonItem) => (a.name > b.name ? 1 : -1)); ).sort((a: AddonItem, b: AddonItem) => (a.name > b.name ? 1 : -1));
this._dialogParams = params; this._dialogParams = params;
try {
this._dialog.open();
} catch {
await this.showDialog(params);
}
} }
protected render(): TemplateResult { protected render(): TemplateResult {
if (!this.snapshot) { if (!this._dialogParams || !this._snapshot) {
return html``; return html``;
} }
return html` return html`
<ha-paper-dialog <ha-dialog
id="dialog" open
with-backdrop="" stacked
.on-iron-overlay-closed=${this._dialogClosed} @closing=${this._closeDialog}
.heading=${createCloseHeading(this.hass, this._computeName)}
> >
<app-toolbar>
<ha-icon-button
icon="hassio:close"
dialog-dismiss=""
></ha-icon-button>
<div main-title="">${this._computeName}</div>
</app-toolbar>
<div class="details"> <div class="details">
${this.snapshot.type === "full" ${this._snapshot.type === "full"
? "Full snapshot" ? "Full snapshot"
: "Partial snapshot"} : "Partial snapshot"}
(${this._computeSize})<br /> (${this._computeSize})<br />
${this._formatDatetime(this.snapshot.date)} ${this._formatDatetime(this._snapshot.date)}
</div> </div>
<div>Home Assistant:</div> <div>Home Assistant:</div>
<paper-checkbox <paper-checkbox
@@ -139,7 +121,7 @@ class HassioSnapshotDialog extends LitElement {
this._restoreHass = (ev.target as PaperCheckboxElement).checked; this._restoreHass = (ev.target as PaperCheckboxElement).checked;
}}" }}"
> >
Home Assistant ${this.snapshot.homeassistant} Home Assistant ${this._snapshot.homeassistant}
</paper-checkbox> </paper-checkbox>
${this._folders.length ${this._folders.length
? html` ? html`
@@ -183,7 +165,7 @@ class HassioSnapshotDialog extends LitElement {
</paper-dialog-scrollable> </paper-dialog-scrollable>
` `
: ""} : ""}
${this.snapshot.protected ${this._snapshot.protected
? html` ? html`
<paper-input <paper-input
autofocus="" autofocus=""
@@ -197,37 +179,35 @@ class HassioSnapshotDialog extends LitElement {
${this._error ? html` <p class="error">Error: ${this._error}</p> ` : ""} ${this._error ? html` <p class="error">Error: ${this._error}</p> ` : ""}
<div>Actions:</div> <div>Actions:</div>
<ul class="buttons">
<li> <mwc-button @click=${this._downloadClicked} slot="primaryAction">
<mwc-button @click=${this._downloadClicked}> <ha-svg-icon path=${mdiDownload} class="icon"></ha-svg-icon>
<ha-icon icon="hassio:download" class="icon"></ha-icon> Download Snapshot
Download Snapshot </mwc-button>
</mwc-button>
</li> <mwc-button
<li> @click=${this._partialRestoreClicked}
<mwc-button @click=${this._partialRestoreClicked}> slot="secondaryAction"
<ha-icon icon="hassio:history" class="icon"> </ha-icon> >
Restore Selected <ha-svg-icon path=${mdiHistory} class="icon"></ha-svg-icon>
</mwc-button> Restore Selected
</li> </mwc-button>
${this.snapshot.type === "full" ${this._snapshot.type === "full"
? html` ? html`
<li> <mwc-button
<mwc-button @click=${this._fullRestoreClicked}> @click=${this._fullRestoreClicked}
<ha-icon icon="hassio:history" class="icon"> </ha-icon> slot="secondaryAction"
Wipe &amp; restore >
</mwc-button> <ha-svg-icon path=${mdiHistory} class="icon"></ha-svg-icon>
</li> Wipe &amp; restore
` </mwc-button>
: ""} `
<li> : ""}
<mwc-button @click=${this._deleteClicked}> <mwc-button @click=${this._deleteClicked} slot="secondaryAction">
<ha-icon icon="hassio:delete" class="icon warning"> </ha-icon> <ha-svg-icon path=${mdiDelete} class="icon warning"></ha-svg-icon>
<span class="warning">Delete Snapshot</span> <span class="warning">Delete Snapshot</span>
</mwc-button> </mwc-button>
</li> </ha-dialog>
</ul>
</ha-paper-dialog>
`; `;
} }
@@ -235,37 +215,10 @@ class HassioSnapshotDialog extends LitElement {
return [ return [
haStyleDialog, haStyleDialog,
css` css`
ha-paper-dialog {
min-width: 350px;
font-size: 14px;
border-radius: 2px;
}
app-toolbar {
margin: 0;
padding: 0 16px;
color: var(--primary-text-color);
background-color: var(--secondary-background-color);
}
app-toolbar [main-title] {
margin-left: 16px;
}
ha-paper-dialog-scrollable {
margin: 0;
}
paper-checkbox { paper-checkbox {
display: block; display: block;
margin: 4px; margin: 4px;
} }
@media all and (max-width: 450px), all and (max-height: 500px) {
ha-paper-dialog {
max-height: 100%;
height: 100%;
}
app-toolbar {
color: var(--text-primary-color);
background-color: var(--primary-color);
}
}
.details { .details {
color: var(--secondary-text-color); color: var(--secondary-text-color);
} }
@@ -336,7 +289,7 @@ class HassioSnapshotDialog extends LitElement {
folders, folders,
}; };
if (this.snapshot!.protected) { if (this._snapshot!.protected) {
data.password = this._snapshotPassword; data.password = this._snapshotPassword;
} }
@@ -344,13 +297,13 @@ class HassioSnapshotDialog extends LitElement {
.callApi( .callApi(
"POST", "POST",
`hassio/snapshots/${this.snapshot!.slug}/restore/partial`, `hassio/snapshots/${this._snapshot!.slug}/restore/partial`,
data data
) )
.then( .then(
() => { () => {
alert("Snapshot restored!"); alert("Snapshot restored!");
this._dialog.close(); this._closeDialog();
}, },
(error) => { (error) => {
this._error = error.body.message; this._error = error.body.message;
@@ -363,20 +316,20 @@ class HassioSnapshotDialog extends LitElement {
return; return;
} }
const data = this.snapshot!.protected const data = this._snapshot!.protected
? { password: this._snapshotPassword } ? { password: this._snapshotPassword }
: undefined; : undefined;
this.hass this.hass
.callApi( .callApi(
"POST", "POST",
`hassio/snapshots/${this.snapshot!.slug}/restore/full`, `hassio/snapshots/${this._snapshot!.slug}/restore/full`,
data data
) )
.then( .then(
() => { () => {
alert("Snapshot restored!"); alert("Snapshot restored!");
this._dialog.close(); this._closeDialog();
}, },
(error) => { (error) => {
this._error = error.body.message; this._error = error.body.message;
@@ -391,11 +344,11 @@ class HassioSnapshotDialog extends LitElement {
this.hass this.hass
.callApi("POST", `hassio/snapshots/${this.snapshot!.slug}/remove`) .callApi("POST", `hassio/snapshots/${this._snapshot!.slug}/remove`)
.then( .then(
() => { () => {
this._dialog.close();
this._dialogParams!.onDelete(); this._dialogParams!.onDelete();
this._closeDialog();
}, },
(error) => { (error) => {
this._error = error.body.message; this._error = error.body.message;
@@ -408,7 +361,7 @@ class HassioSnapshotDialog extends LitElement {
try { try {
signedPath = await getSignedPath( signedPath = await getSignedPath(
this.hass, this.hass,
`/api/hassio/snapshots/${this.snapshot!.slug}/download` `/api/hassio/snapshots/${this._snapshot!.slug}/download`
); );
} catch (err) { } catch (err) {
alert(`Error: ${err.message}`); alert(`Error: ${err.message}`);
@@ -419,19 +372,19 @@ class HassioSnapshotDialog extends LitElement {
const a = document.createElement("a"); const a = document.createElement("a");
a.href = signedPath.path; a.href = signedPath.path;
a.download = `Hass_io_${name}.tar`; a.download = `Hass_io_${name}.tar`;
this._dialog.appendChild(a); this.shadowRoot!.appendChild(a);
a.click(); a.click();
this._dialog.removeChild(a); this.shadowRoot!.removeChild(a);
} }
private get _computeName() { private get _computeName() {
return this.snapshot return this._snapshot
? this.snapshot.name || this.snapshot.slug ? this._snapshot.name || this._snapshot.slug
: "Unnamed snapshot"; : "Unnamed snapshot";
} }
private get _computeSize() { private get _computeSize() {
return Math.ceil(this.snapshot!.size * 10) / 10 + " MB"; return Math.ceil(this._snapshot!.size * 10) / 10 + " MB";
} }
private _formatDatetime(datetime) { private _formatDatetime(datetime) {
@@ -445,9 +398,9 @@ class HassioSnapshotDialog extends LitElement {
}); });
} }
private _dialogClosed() { private _closeDialog() {
this._dialogParams = undefined; this._dialogParams = undefined;
this.snapshot = undefined; this._snapshot = undefined;
this._snapshotPassword = ""; this._snapshotPassword = "";
this._folders = []; this._folders = [];
this._addons = []; this._addons = [];

View File

@@ -3,11 +3,11 @@ import {
HassioAddonDetails, HassioAddonDetails,
restartHassioAddon, restartHassioAddon,
} from "../../../src/data/hassio/addon"; } from "../../../src/data/hassio/addon";
import { HomeAssistant } from "../../../src/types";
import { import {
showConfirmationDialog,
showAlertDialog, showAlertDialog,
showConfirmationDialog,
} from "../../../src/dialogs/generic/show-dialog-box"; } from "../../../src/dialogs/generic/show-dialog-box";
import { HomeAssistant } from "../../../src/types";
export const suggestAddonRestart = async ( export const suggestAddonRestart = async (
element: LitElement, element: LitElement,

View File

@@ -1,4 +1,3 @@
import "../../src/components/ha-icon-button";
import { PolymerElement } from "@polymer/polymer"; import { PolymerElement } from "@polymer/polymer";
import { customElement, property, PropertyValues } from "lit-element"; import { customElement, property, PropertyValues } from "lit-element";
import { applyThemesOnElement } from "../../src/common/dom/apply_themes_on_element"; import { applyThemesOnElement } from "../../src/common/dom/apply_themes_on_element";
@@ -34,12 +33,6 @@ import { HomeAssistant } from "../../src/types";
// Don't codesplit it, that way the dashboard always loads fast. // Don't codesplit it, that way the dashboard always loads fast.
import "./hassio-panel"; import "./hassio-panel";
// The register callback of the IronA11yKeysBehavior inside ha-icon-button
// is not called, causing _keyBindings to be uninitiliazed for ha-icon-button,
// causing an exception when added to DOM. When transpiled to ES5, this will
// break the build.
customElements.get("ha-icon-button").prototype._keyBindings = {};
@customElement("hassio-main") @customElement("hassio-main")
class HassioMain extends ProvideHassLitMixin(HassRouterPage) { class HassioMain extends ProvideHassLitMixin(HassRouterPage) {
@property() public hass!: HomeAssistant; @property() public hass!: HomeAssistant;

View File

@@ -1,3 +1,4 @@
import { mdiBackupRestore, mdiCogs, mdiStore, mdiViewDashboard } from "@mdi/js";
import { import {
customElement, customElement,
html, html,
@@ -5,37 +6,36 @@ import {
property, property,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { HassioHassOSInfo, HassioHostInfo } from "../../src/data/hassio/host"; import { HassioHassOSInfo, HassioHostInfo } from "../../src/data/hassio/host";
import { import {
HassioHomeAssistantInfo, HassioHomeAssistantInfo,
HassioSupervisorInfo, HassioSupervisorInfo,
} from "../../src/data/hassio/supervisor"; } from "../../src/data/hassio/supervisor";
import type { PageNavigation } from "../../src/layouts/hass-tabs-subpage";
import "../../src/resources/ha-style"; import "../../src/resources/ha-style";
import { HomeAssistant, Route } from "../../src/types"; import { HomeAssistant, Route } from "../../src/types";
import "./hassio-panel-router"; import "./hassio-panel-router";
import type { PageNavigation } from "../../src/layouts/hass-tabs-subpage";
export const supervisorTabs: PageNavigation[] = [ export const supervisorTabs: PageNavigation[] = [
{ {
name: "Dashboard", name: "Dashboard",
path: `/hassio/dashboard`, path: `/hassio/dashboard`,
icon: "hassio:view-dashboard", iconPath: mdiViewDashboard,
}, },
{ {
name: "Add-on store", name: "Add-on store",
path: `/hassio/store`, path: `/hassio/store`,
icon: "hassio:store", iconPath: mdiStore,
}, },
{ {
name: "Snapshots", name: "Snapshots",
path: `/hassio/snapshots`, path: `/hassio/snapshots`,
icon: "hassio:backup-restore", iconPath: mdiBackupRestore,
}, },
{ {
name: "System", name: "System",
path: `/hassio/system`, path: `/hassio/system`,
icon: "hassio:cogs", iconPath: mdiCogs,
}, },
]; ];

View File

@@ -86,9 +86,6 @@ class HassioIngressView extends LitElement {
height: 100%; height: 100%;
border: 0; border: 0;
} }
ha-icon-button {
color: var(--text-primary-color);
}
`; `;
} }
} }

View File

@@ -1,5 +1,6 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/paper-card/paper-card"; import "@material/mwc-icon-button";
import { mdiPackageVariant, mdiPackageVariantClosed, mdiReload } from "@mdi/js";
import "@polymer/paper-checkbox/paper-checkbox"; import "@polymer/paper-checkbox/paper-checkbox";
import type { PaperCheckboxElement } from "@polymer/paper-checkbox/paper-checkbox"; import type { PaperCheckboxElement } from "@polymer/paper-checkbox/paper-checkbox";
import "@polymer/paper-input/paper-input"; import "@polymer/paper-input/paper-input";
@@ -18,6 +19,8 @@ import {
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { fireEvent } from "../../../src/common/dom/fire_event"; import { fireEvent } from "../../../src/common/dom/fire_event";
import "../../../src/components/ha-card";
import "../../../src/components/ha-svg-icon";
import { import {
createHassioFullSnapshot, createHassioFullSnapshot,
createHassioPartialSnapshot, createHassioPartialSnapshot,
@@ -28,15 +31,14 @@ import {
reloadHassioSnapshots, reloadHassioSnapshots,
} from "../../../src/data/hassio/snapshot"; } from "../../../src/data/hassio/snapshot";
import { HassioSupervisorInfo } from "../../../src/data/hassio/supervisor"; import { HassioSupervisorInfo } from "../../../src/data/hassio/supervisor";
import "../../../src/layouts/hass-tabs-subpage";
import { PolymerChangedEvent } from "../../../src/polymer-types"; import { PolymerChangedEvent } from "../../../src/polymer-types";
import { haStyle } from "../../../src/resources/styles"; import { haStyle } from "../../../src/resources/styles";
import { HomeAssistant, Route } from "../../../src/types"; import { HomeAssistant, Route } from "../../../src/types";
import "../../../src/layouts/hass-tabs-subpage";
import "../components/hassio-card-content"; import "../components/hassio-card-content";
import { showHassioSnapshotDialog } from "../dialogs/snapshot/show-dialog-hassio-snapshot"; import { showHassioSnapshotDialog } from "../dialogs/snapshot/show-dialog-hassio-snapshot";
import { hassioStyle } from "../resources/hassio-style";
import { supervisorTabs } from "../hassio-panel"; import { supervisorTabs } from "../hassio-panel";
import { hassioStyle } from "../resources/hassio-style";
interface CheckboxItem { interface CheckboxItem {
slug: string; slug: string;
@@ -98,12 +100,13 @@ class HassioSnapshots extends LitElement {
> >
<span slot="header">Snapshots</span> <span slot="header">Snapshots</span>
<ha-icon-button <mwc-icon-button
icon="hassio:reload"
slot="toolbar-icon" slot="toolbar-icon"
aria-label="Reload snapshots" aria-label="Reload snapshots"
@click=${this.refreshData} @click=${this.refreshData}
></ha-icon-button> >
<ha-svg-icon path=${mdiReload}></ha-svg-icon>
</mwc-icon-button>
<div class="content"> <div class="content">
<h1> <h1>
@@ -114,7 +117,7 @@ class HassioSnapshots extends LitElement {
Home Assistant instance. Home Assistant instance.
</p> </p>
<div class="card-group"> <div class="card-group">
<paper-card> <ha-card>
<div class="card-content"> <div class="card-content">
<paper-input <paper-input
autofocus autofocus
@@ -195,7 +198,7 @@ class HassioSnapshots extends LitElement {
Create Create
</mwc-button> </mwc-button>
</div> </div>
</paper-card> </ha-card>
</div> </div>
<h1>Available snapshots</h1> <h1>Available snapshots</h1>
@@ -204,15 +207,15 @@ class HassioSnapshots extends LitElement {
? undefined ? undefined
: this._snapshots.length === 0 : this._snapshots.length === 0
? html` ? html`
<paper-card> <ha-card>
<div class="card-content"> <div class="card-content">
You don't have any snapshots yet. You don't have any snapshots yet.
</div> </div>
</paper-card> </ha-card>
` `
: this._snapshots.map( : this._snapshots.map(
(snapshot) => html` (snapshot) => html`
<paper-card <ha-card
class="pointer" class="pointer"
.snapshot=${snapshot} .snapshot=${snapshot}
@click=${this._snapshotClicked} @click=${this._snapshotClicked}
@@ -224,12 +227,12 @@ class HassioSnapshots extends LitElement {
.description=${this._computeDetails(snapshot)} .description=${this._computeDetails(snapshot)}
.datetime=${snapshot.date} .datetime=${snapshot.date}
.icon=${snapshot.type === "full" .icon=${snapshot.type === "full"
? "hassio:package-variant-closed" ? mdiPackageVariantClosed
: "hassio:package-variant"} : mdiPackageVariant}
.icon-class="snapshot" .icon-class="snapshot"
></hassio-card-content> ></hassio-card-content>
</div> </div>
</paper-card> </ha-card>
` `
)} )}
</div> </div>

View File

@@ -1,5 +1,4 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/paper-card/paper-card";
import { import {
css, css,
CSSResult, CSSResult,
@@ -12,23 +11,23 @@ import {
import "../../../src/components/buttons/ha-call-api-button"; import "../../../src/components/buttons/ha-call-api-button";
import { fetchHassioHardwareInfo } from "../../../src/data/hassio/hardware"; import { fetchHassioHardwareInfo } from "../../../src/data/hassio/hardware";
import { import {
changeHostOptions,
fetchHassioHostInfo, fetchHassioHostInfo,
HassioHassOSInfo, HassioHassOSInfo,
HassioHostInfo as HassioHostInfoType, HassioHostInfo as HassioHostInfoType,
rebootHost, rebootHost,
shutdownHost, shutdownHost,
updateOS, updateOS,
changeHostOptions,
} from "../../../src/data/hassio/host"; } from "../../../src/data/hassio/host";
import {
showAlertDialog,
showConfirmationDialog,
showPromptDialog,
} from "../../../src/dialogs/generic/show-dialog-box";
import { haStyle } from "../../../src/resources/styles"; import { haStyle } from "../../../src/resources/styles";
import { HomeAssistant } from "../../../src/types"; import { HomeAssistant } from "../../../src/types";
import { showHassioMarkdownDialog } from "../dialogs/markdown/show-dialog-hassio-markdown"; import { showHassioMarkdownDialog } from "../dialogs/markdown/show-dialog-hassio-markdown";
import { hassioStyle } from "../resources/hassio-style"; import { hassioStyle } from "../resources/hassio-style";
import {
showConfirmationDialog,
showAlertDialog,
showPromptDialog,
} from "../../../src/dialogs/generic/show-dialog-box";
@customElement("hassio-host-info") @customElement("hassio-host-info")
class HassioHostInfo extends LitElement { class HassioHostInfo extends LitElement {
@@ -42,7 +41,7 @@ class HassioHostInfo extends LitElement {
public render(): TemplateResult | void { public render(): TemplateResult | void {
return html` return html`
<paper-card> <ha-card>
<div class="card-content"> <div class="card-content">
<h2>Host system</h2> <h2>Host system</h2>
<table class="info"> <table class="info">
@@ -113,7 +112,7 @@ class HassioHostInfo extends LitElement {
? html` <mwc-button @click=${this._updateOS}>Update</mwc-button> ` ? html` <mwc-button @click=${this._updateOS}>Update</mwc-button> `
: ""} : ""}
</div> </div>
</paper-card> </ha-card>
`; `;
} }
@@ -122,7 +121,7 @@ class HassioHostInfo extends LitElement {
haStyle, haStyle,
hassioStyle, hassioStyle,
css` css`
paper-card { ha-card {
height: 100%; height: 100%;
width: 100%; width: 100%;
} }

View File

@@ -1,5 +1,4 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/paper-card/paper-card";
import { import {
css, css,
CSSResult, CSSResult,
@@ -11,15 +10,16 @@ import {
} from "lit-element"; } from "lit-element";
import { fireEvent } from "../../../src/common/dom/fire_event"; import { fireEvent } from "../../../src/common/dom/fire_event";
import "../../../src/components/buttons/ha-call-api-button"; import "../../../src/components/buttons/ha-call-api-button";
import "../../../src/components/ha-card";
import { import {
HassioSupervisorInfo as HassioSupervisorInfoType, HassioSupervisorInfo as HassioSupervisorInfoType,
setSupervisorOption, setSupervisorOption,
SupervisorOptions, SupervisorOptions,
} from "../../../src/data/hassio/supervisor"; } from "../../../src/data/hassio/supervisor";
import { showConfirmationDialog } from "../../../src/dialogs/generic/show-dialog-box";
import { haStyle } from "../../../src/resources/styles"; import { haStyle } from "../../../src/resources/styles";
import { HomeAssistant } from "../../../src/types"; import { HomeAssistant } from "../../../src/types";
import { hassioStyle } from "../resources/hassio-style"; import { hassioStyle } from "../resources/hassio-style";
import { showConfirmationDialog } from "../../../src/dialogs/generic/show-dialog-box";
@customElement("hassio-supervisor-info") @customElement("hassio-supervisor-info")
class HassioSupervisorInfo extends LitElement { class HassioSupervisorInfo extends LitElement {
@@ -31,7 +31,7 @@ class HassioSupervisorInfo extends LitElement {
public render(): TemplateResult | void { public render(): TemplateResult | void {
return html` return html`
<paper-card> <ha-card>
<div class="card-content"> <div class="card-content">
<h2>Supervisor</h2> <h2>Supervisor</h2>
<table class="info"> <table class="info">
@@ -92,7 +92,7 @@ class HassioSupervisorInfo extends LitElement {
` `
: ""} : ""}
</div> </div>
</paper-card> </ha-card>
`; `;
} }
@@ -101,7 +101,7 @@ class HassioSupervisorInfo extends LitElement {
haStyle, haStyle,
hassioStyle, hassioStyle,
css` css`
paper-card { ha-card {
height: 100%; height: 100%;
width: 100%; width: 100%;
} }

View File

@@ -2,7 +2,6 @@ import "@material/mwc-button";
import "@polymer/paper-dropdown-menu/paper-dropdown-menu"; import "@polymer/paper-dropdown-menu/paper-dropdown-menu";
import "@polymer/paper-item/paper-item"; import "@polymer/paper-item/paper-item";
import "@polymer/paper-listbox/paper-listbox"; import "@polymer/paper-listbox/paper-listbox";
import "@polymer/paper-card/paper-card";
import { import {
css, css,
CSSResult, CSSResult,
@@ -12,14 +11,13 @@ import {
property, property,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import "../../../src/components/ha-card";
import { fetchHassioLogs } from "../../../src/data/hassio/supervisor";
import "../../../src/layouts/loading-screen";
import { haStyle } from "../../../src/resources/styles"; import { haStyle } from "../../../src/resources/styles";
import { HomeAssistant } from "../../../src/types"; import { HomeAssistant } from "../../../src/types";
import { fetchHassioLogs } from "../../../src/data/hassio/supervisor";
import "../components/hassio-ansi-to-html"; import "../components/hassio-ansi-to-html";
import { hassioStyle } from "../resources/hassio-style"; import { hassioStyle } from "../resources/hassio-style";
import "../../../src/layouts/loading-screen";
interface LogProvider { interface LogProvider {
key: string; key: string;
@@ -70,7 +68,7 @@ class HassioSupervisorLog extends LitElement {
public render(): TemplateResult | void { public render(): TemplateResult | void {
return html` return html`
<paper-card> <ha-card>
${this._error ? html` <div class="errors">${this._error}</div> ` : ""} ${this._error ? html` <div class="errors">${this._error}</div> ` : ""}
${this.hass.userData?.showAdvanced ${this.hass.userData?.showAdvanced
? html` ? html`
@@ -105,7 +103,7 @@ class HassioSupervisorLog extends LitElement {
<div class="card-actions"> <div class="card-actions">
<mwc-button @click=${this._refresh}>Refresh</mwc-button> <mwc-button @click=${this._refresh}>Refresh</mwc-button>
</div> </div>
</paper-card> </ha-card>
`; `;
} }
@@ -114,7 +112,7 @@ class HassioSupervisorLog extends LitElement {
haStyle, haStyle,
hassioStyle, hassioStyle,
css` css`
paper-card { ha-card {
width: 100%; width: 100%;
} }
pre { pre {

View File

@@ -13,16 +13,15 @@ import {
HassioHostInfo, HassioHostInfo,
} from "../../../src/data/hassio/host"; } from "../../../src/data/hassio/host";
import { HassioSupervisorInfo } from "../../../src/data/hassio/supervisor"; import { HassioSupervisorInfo } from "../../../src/data/hassio/supervisor";
import { haStyle } from "../../../src/resources/styles";
import "../../../src/layouts/hass-tabs-subpage"; import "../../../src/layouts/hass-tabs-subpage";
import { haStyle } from "../../../src/resources/styles";
import { HomeAssistant, Route } from "../../../src/types"; import { HomeAssistant, Route } from "../../../src/types";
import { supervisorTabs } from "../hassio-panel";
import { hassioStyle } from "../resources/hassio-style"; import { hassioStyle } from "../resources/hassio-style";
import "./hassio-host-info"; import "./hassio-host-info";
import "./hassio-supervisor-info"; import "./hassio-supervisor-info";
import "./hassio-supervisor-log"; import "./hassio-supervisor-log";
import { supervisorTabs } from "../hassio-panel";
@customElement("hassio-system") @customElement("hassio-system")
class HassioSystem extends LitElement { class HassioSystem extends LitElement {
@property({ attribute: false }) public hass!: HomeAssistant; @property({ attribute: false }) public hass!: HomeAssistant;

View File

@@ -24,19 +24,20 @@
"author": "Paulus Schoutsen <Paulus@PaulusSchoutsen.nl> (http://paulusschoutsen.nl)", "author": "Paulus Schoutsen <Paulus@PaulusSchoutsen.nl> (http://paulusschoutsen.nl)",
"license": "Apache-2.0", "license": "Apache-2.0",
"dependencies": { "dependencies": {
"@fullcalendar/core": "5.0.0-beta.2", "@formatjs/intl-pluralrules": "^1.5.8",
"@fullcalendar/daygrid": "5.0.0-beta.2", "@fullcalendar/core": "^5.0.0-beta.2",
"@material/chips": "^6.0.0-canary.35a32aaea.0", "@fullcalendar/daygrid": "^5.0.0-beta.2",
"@material/mwc-button": "0.14.1", "@material/chips": "7.0.0-canary.d92d8c93e.0",
"@material/mwc-checkbox": "0.14.1", "@material/mwc-button": "^0.15.0",
"@material/mwc-dialog": "0.14.1", "@material/mwc-checkbox": "^0.15.0",
"@material/mwc-fab": "0.14.1", "@material/mwc-dialog": "^0.15.0",
"@material/mwc-formfield": "0.14.1", "@material/mwc-fab": "^0.15.0",
"@material/mwc-icon-button": "0.14.1", "@material/mwc-formfield": "^0.15.0",
"@material/mwc-list": "0.14.1", "@material/mwc-icon-button": "^0.15.0",
"@material/mwc-menu": "0.14.1", "@material/mwc-list": "^0.15.0",
"@material/mwc-ripple": "0.14.1", "@material/mwc-menu": "^0.15.0",
"@material/mwc-switch": "0.14.1", "@material/mwc-ripple": "^0.15.0",
"@material/mwc-switch": "^0.15.0",
"@mdi/js": "4.9.95", "@mdi/js": "4.9.95",
"@mdi/svg": "4.9.95", "@mdi/svg": "4.9.95",
"@polymer/app-layout": "^3.0.2", "@polymer/app-layout": "^3.0.2",
@@ -77,7 +78,7 @@
"@polymer/paper-toast": "^3.0.1", "@polymer/paper-toast": "^3.0.1",
"@polymer/paper-tooltip": "^3.0.1", "@polymer/paper-tooltip": "^3.0.1",
"@polymer/polymer": "3.1.0", "@polymer/polymer": "3.1.0",
"@thomasloven/round-slider": "0.3.7", "@thomasloven/round-slider": "0.4.1",
"@vaadin/vaadin-combo-box": "^5.0.10", "@vaadin/vaadin-combo-box": "^5.0.10",
"@vaadin/vaadin-date-picker": "^4.0.7", "@vaadin/vaadin-date-picker": "^4.0.7",
"@webcomponents/shadycss": "^1.9.0", "@webcomponents/shadycss": "^1.9.0",
@@ -93,14 +94,14 @@
"fuse.js": "^3.4.4", "fuse.js": "^3.4.4",
"google-timezones-json": "^1.0.2", "google-timezones-json": "^1.0.2",
"hls.js": "^0.12.4", "hls.js": "^0.12.4",
"home-assistant-js-websocket": "5.0.0", "home-assistant-js-websocket": "^5.1.2",
"idb-keyval": "^3.2.0", "idb-keyval": "^3.2.0",
"intl-messageformat": "^8.3.9", "intl-messageformat": "^8.3.9",
"js-yaml": "^3.13.1", "js-yaml": "^3.13.1",
"leaflet": "^1.4.0", "leaflet": "^1.4.0",
"leaflet-draw": "^1.0.4", "leaflet-draw": "^1.0.4",
"lit-element": "^2.2.1", "lit-element": "^2.3.1",
"lit-html": "^1.1.0", "lit-html": "^1.2.1",
"lit-virtualizer": "^0.4.2", "lit-virtualizer": "^0.4.2",
"marked": "^0.6.1", "marked": "^0.6.1",
"mdn-polyfills": "^5.16.0", "mdn-polyfills": "^5.16.0",
@@ -114,6 +115,10 @@
"tslib": "^1.10.0", "tslib": "^1.10.0",
"unfetch": "^4.1.0", "unfetch": "^4.1.0",
"web-animations-js": "^2.3.2", "web-animations-js": "^2.3.2",
"workbox-core": "^5.1.3",
"workbox-precaching": "^5.1.3",
"workbox-routing": "^5.1.3",
"workbox-strategies": "^5.1.3",
"xss": "^1.0.6" "xss": "^1.0.6"
}, },
"devDependencies": { "devDependencies": {
@@ -177,6 +182,7 @@
"reify": "^0.18.1", "reify": "^0.18.1",
"require-dir": "^1.2.0", "require-dir": "^1.2.0",
"sinon": "^7.3.1", "sinon": "^7.3.1",
"source-map-url": "^0.4.0",
"terser-webpack-plugin": "^1.2.3", "terser-webpack-plugin": "^1.2.3",
"ts-lit-plugin": "^1.1.10", "ts-lit-plugin": "^1.1.10",
"ts-mocha": "^6.0.0", "ts-mocha": "^6.0.0",
@@ -188,7 +194,7 @@
"webpack-cli": "^3.3.9", "webpack-cli": "^3.3.9",
"webpack-dev-server": "^3.10.3", "webpack-dev-server": "^3.10.3",
"webpack-manifest-plugin": "^2.0.4", "webpack-manifest-plugin": "^2.0.4",
"workbox-webpack-plugin": "^4.1.1", "workbox-build": "^5.1.3",
"workerize-loader": "^1.1.0" "workerize-loader": "^1.1.0"
}, },
"_comment": "Polymer fixed to 3.1 because 3.2 throws on logbook page", "_comment": "Polymer fixed to 3.1 because 3.2 throws on logbook page",
@@ -196,20 +202,21 @@
"resolutions": { "resolutions": {
"@webcomponents/webcomponentsjs": "^2.2.10", "@webcomponents/webcomponentsjs": "^2.2.10",
"@polymer/polymer": "3.1.0", "@polymer/polymer": "3.1.0",
"lit-html": "^1.1.2", "lit-html": "1.2.1",
"@material/animation": "6.0.0", "lit-element": "2.3.1",
"@material/base": "6.0.0", "@material/animation": "7.0.0-canary.d92d8c93e.0",
"@material/checkbox": "6.0.0", "@material/base": "7.0.0-canary.d92d8c93e.0",
"@material/density": "6.0.0", "@material/checkbox": "7.0.0-canary.d92d8c93e.0",
"@material/dom": "6.0.0", "@material/density": "7.0.0-canary.d92d8c93e.0",
"@material/elevation": "6.0.0", "@material/dom": "7.0.0-canary.d92d8c93e.0",
"@material/feature-targeting": "6.0.0", "@material/elevation": "7.0.0-canary.d92d8c93e.0",
"@material/ripple": "6.0.0", "@material/feature-targeting": "7.0.0-canary.d92d8c93e.0",
"@material/rtl": "6.0.0", "@material/ripple": "7.0.0-canary.d92d8c93e.0",
"@material/shape": "6.0.0", "@material/rtl": "7.0.0-canary.d92d8c93e.0",
"@material/theme": "6.0.0", "@material/shape": "7.0.0-canary.d92d8c93e.0",
"@material/touch-target": "6.0.0", "@material/theme": "7.0.0-canary.d92d8c93e.0",
"@material/typography": "6.0.0" "@material/touch-target": "7.0.0-canary.d92d8c93e.0",
"@material/typography": "7.0.0-canary.d92d8c93e.0"
}, },
"main": "src/home-assistant.js", "main": "src/home-assistant.js",
"husky": { "husky": {

Binary file not shown.

Before

Width:  |  Height:  |  Size: 655 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 888 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 807 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 639 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 840 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 798 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 487 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 774 B

View File

@@ -2,7 +2,7 @@ from setuptools import setup, find_packages
setup( setup(
name="home-assistant-frontend", name="home-assistant-frontend",
version="20200505.0", version="20200515.0",
description="The Home Assistant frontend", description="The Home Assistant frontend",
url="https://github.com/home-assistant/home-assistant-polymer", url="https://github.com/home-assistant/home-assistant-polymer",
author="The Home Assistant Authors", author="The Home Assistant Authors",

View File

@@ -121,7 +121,7 @@ class HaAuthorize extends litLocalizeLiteMixin(LitElement) {
const tempA = document.createElement("a"); const tempA = document.createElement("a");
tempA.href = this.redirectUri!; tempA.href = this.redirectUri!;
if (tempA.host === location.host) { if (tempA.host === location.host) {
registerServiceWorker(false); registerServiceWorker(this, false);
} }
} }

View File

@@ -1,5 +1,5 @@
import "@polymer/paper-item/paper-item.js"; import "@polymer/paper-item/paper-item";
import "@polymer/paper-item/paper-item-body.js"; import "@polymer/paper-item/paper-item-body";
import { html, LitElement, property } from "lit-element"; import { html, LitElement, property } from "lit-element";
import { fireEvent } from "../common/dom/fire_event"; import { fireEvent } from "../common/dom/fire_event";
import "../components/ha-icon-next"; import "../components/ha-icon-next";

View File

@@ -1,7 +1,7 @@
import "@polymer/paper-card"; import "@polymer/paper-card/paper-card";
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { computeStateName } from "../common/entity/compute_state_name"; import { computeStateName } from "../common/entity/compute_state_name";
import "../components/state-history-charts"; import "../components/state-history-charts";
import "../data/ha-state-history-data"; import "../data/ha-state-history-data";

View File

@@ -1,5 +1,4 @@
import "../../components/ha-icon-button"; import "@polymer/paper-input/paper-input";
import "@polymer/paper-input/paper-input.js";
import { import {
css, css,
CSSResult, CSSResult,
@@ -8,9 +7,11 @@ import {
property, property,
} from "lit-element"; } from "lit-element";
import { html, TemplateResult } from "lit-html"; import { html, TemplateResult } from "lit-html";
import { classMap } from "lit-html/directives/class-map.js"; import { classMap } from "lit-html/directives/class-map";
import "../../components/ha-icon"; import "../../components/ha-svg-icon";
import { fireEvent } from "../dom/fire_event"; import { fireEvent } from "../dom/fire_event";
import { mdiMagnify, mdiClose } from "@mdi/js";
import "@material/mwc-icon-button/mwc-icon-button";
@customElement("search-input") @customElement("search-input")
class SearchInput extends LitElement { class SearchInput extends LitElement {
@@ -47,17 +48,22 @@ class SearchInput extends LitElement {
@value-changed=${this._filterInputChanged} @value-changed=${this._filterInputChanged}
.noLabelFloat=${this.noLabelFloat} .noLabelFloat=${this.noLabelFloat}
> >
<ha-icon icon="hass:magnify" slot="prefix" class="prefix"></ha-icon> <ha-svg-icon
path=${mdiMagnify}
slot="prefix"
class="prefix"
></ha-svg-icon>
${this.filter && ${this.filter &&
html` html`
<ha-icon-button <mwc-icon-button
slot="suffix" slot="suffix"
class="suffix" class="suffix"
@click=${this._clearSearch} @click=${this._clearSearch}
icon="hass:close"
alt="Clear" alt="Clear"
title="Clear" title="Clear"
></ha-icon-button> >
<ha-svg-icon path=${mdiClose}></ha-svg-icon>
</mwc-icon-button>
`} `}
</paper-input> </paper-input>
`; `;
@@ -77,11 +83,14 @@ class SearchInput extends LitElement {
static get styles(): CSSResult { static get styles(): CSSResult {
return css` return css`
ha-icon, ha-svg-icon,
ha-icon-button { mwc-icon-button {
color: var(--primary-text-color); color: var(--primary-text-color);
} }
ha-icon { mwc-icon-button {
--mdc-icon-button-size: 24px;
}
ha-svg-icon.prefix {
margin: 8px; margin: 8px;
} }
`; `;

View File

@@ -12,6 +12,10 @@ export interface FormatsType {
time: FormatType; time: FormatType;
} }
if (!Intl.PluralRules) {
import("@formatjs/intl-pluralrules/polyfill-locales");
}
/** /**
* Adapted from Polymer app-localize-behavior. * Adapted from Polymer app-localize-behavior.
* *

View File

@@ -1,6 +1,6 @@
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { showConfirmationDialog } from "../../dialogs/generic/show-dialog-box"; import { showConfirmationDialog } from "../../dialogs/generic/show-dialog-box";
import { EventsMixin } from "../../mixins/events-mixin"; import { EventsMixin } from "../../mixins/events-mixin";
import "./ha-progress-button"; import "./ha-progress-button";

View File

@@ -1,8 +1,8 @@
import "@material/mwc-button"; import "@material/mwc-button";
import "@polymer/paper-spinner/paper-spinner.js"; import "@polymer/paper-spinner/paper-spinner";
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
class HaProgressButton extends PolymerElement { class HaProgressButton extends PolymerElement {
static get template() { static get template() {

View File

@@ -10,9 +10,9 @@ import {
query, query,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { classMap } from "lit-html/directives/class-map.js"; import { classMap } from "lit-html/directives/class-map";
import { ifDefined } from "lit-html/directives/if-defined.js"; import { ifDefined } from "lit-html/directives/if-defined";
import { styleMap } from "lit-html/directives/style-map.js"; import { styleMap } from "lit-html/directives/style-map";
import { scroll } from "lit-virtualizer"; import { scroll } from "lit-virtualizer";
// @ts-ignore // @ts-ignore
// eslint-disable-next-line import/no-webpack-loader-syntax // eslint-disable-next-line import/no-webpack-loader-syntax
@@ -646,6 +646,11 @@ export class HaDataTable extends LitElement {
padding: 8px; padding: 8px;
} }
.mdc-data-table__cell--icon-button {
color: var(--secondary-text-color);
text-overflow: clip;
}
.mdc-data-table__header-cell--icon-button:first-child, .mdc-data-table__header-cell--icon-button:first-child,
.mdc-data-table__cell--icon-button:first-child { .mdc-data-table__cell--icon-button:first-child {
width: 64px; width: 64px;
@@ -659,7 +664,7 @@ export class HaDataTable extends LitElement {
} }
.mdc-data-table__cell--icon-button a { .mdc-data-table__cell--icon-button a {
color: var(--primary-text-color); color: var(--secondary-text-color);
} }
.mdc-data-table__header-cell { .mdc-data-table__header-cell {

View File

@@ -1,10 +1,10 @@
import "@material/mwc-button"; import "@material/mwc-button/mwc-button";
import "../ha-icon-button"; import "../ha-icon-button";
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import "@polymer/paper-item/paper-item.js"; import "@polymer/paper-item/paper-item";
import "@polymer/paper-item/paper-item-body.js"; import "@polymer/paper-item/paper-item-body";
import "@polymer/paper-listbox"; import "@polymer/paper-listbox/paper-listbox";
import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light.js"; import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light";
import { UnsubscribeFunc } from "home-assistant-js-websocket"; import { UnsubscribeFunc } from "home-assistant-js-websocket";
import { import {
css, css,

View File

@@ -1,7 +1,7 @@
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import "@polymer/paper-item/paper-item.js"; import "@polymer/paper-item/paper-item";
import "@polymer/paper-item/paper-item-body.js"; import "@polymer/paper-item/paper-item-body";
import "@polymer/paper-listbox"; import "@polymer/paper-listbox/paper-listbox";
import { import {
css, css,
CSSResult, CSSResult,

View File

@@ -1,9 +1,9 @@
import "../ha-icon-button"; import "../ha-icon-button";
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import "@polymer/paper-item/paper-item.js"; import "@polymer/paper-item/paper-item";
import "@polymer/paper-item/paper-item-body.js"; import "@polymer/paper-item/paper-item-body";
import "@polymer/paper-listbox"; import "@polymer/paper-listbox/paper-listbox";
import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light.js"; import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light";
import { UnsubscribeFunc } from "home-assistant-js-websocket"; import { UnsubscribeFunc } from "home-assistant-js-websocket";
import { import {
css, css,

View File

@@ -11,8 +11,8 @@ found at http://polymer.github.io/PATENTS.txt
/* /*
Fixes issue with not using shadow dom properly in iron-overlay-behavior/icon-focusables-helper.js Fixes issue with not using shadow dom properly in iron-overlay-behavior/icon-focusables-helper.js
*/ */
import { IronFocusablesHelper } from "@polymer/iron-overlay-behavior/iron-focusables-helper.js"; import { IronFocusablesHelper } from "@polymer/iron-overlay-behavior/iron-focusables-helper";
import { dom } from "@polymer/polymer/lib/legacy/polymer.dom.js"; import { dom } from "@polymer/polymer/lib/legacy/polymer.dom";
export const HaIronFocusablesHelper = { export const HaIronFocusablesHelper = {
/** /**

View File

@@ -1,6 +1,6 @@
import "@polymer/paper-dialog"; import "@polymer/paper-dialog/paper-dialog";
import type { PaperDialogElement } from "@polymer/paper-dialog"; import type { PaperDialogElement } from "@polymer/paper-dialog/paper-dialog";
import { mixinBehaviors } from "@polymer/polymer/lib/legacy/class.js"; import { mixinBehaviors } from "@polymer/polymer/lib/legacy/class";
import type { Constructor } from "../../types"; import type { Constructor } from "../../types";
import { HaIronFocusablesHelper } from "./ha-iron-focusables-helper"; import { HaIronFocusablesHelper } from "./ha-iron-focusables-helper";

View File

@@ -1,11 +1,11 @@
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { IronResizableBehavior } from "@polymer/iron-resizable-behavior"; import { IronResizableBehavior } from "@polymer/iron-resizable-behavior/iron-resizable-behavior";
import "../ha-icon-button"; import "../ha-icon-button";
import { mixinBehaviors } from "@polymer/polymer/lib/legacy/class.js"; import { mixinBehaviors } from "@polymer/polymer/lib/legacy/class";
import { timeOut } from "@polymer/polymer/lib/utils/async.js"; import { timeOut } from "@polymer/polymer/lib/utils/async";
import { Debouncer } from "@polymer/polymer/lib/utils/debounce.js"; import { Debouncer } from "@polymer/polymer/lib/utils/debounce";
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { formatTime } from "../../common/datetime/format_time"; import { formatTime } from "../../common/datetime/format_time";
// eslint-disable-next-line no-unused-vars // eslint-disable-next-line no-unused-vars

View File

@@ -1,8 +1,8 @@
import "../ha-icon-button"; import "../ha-icon-button";
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import "@polymer/paper-item/paper-icon-item.js"; import "@polymer/paper-item/paper-icon-item";
import "@polymer/paper-item/paper-item-body.js"; import "@polymer/paper-item/paper-item-body";
import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light.js"; import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light";
import { HassEntity } from "home-assistant-js-websocket"; import { HassEntity } from "home-assistant-js-websocket";
import { import {
css, css,

View File

@@ -1,6 +1,6 @@
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { stateIcon } from "../../common/entity/state_icon"; import { stateIcon } from "../../common/entity/state_icon";
import "../ha-icon"; import "../ha-icon";

View File

@@ -9,7 +9,7 @@ import {
PropertyValues, PropertyValues,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { classMap } from "lit-html/directives/class-map.js"; import { classMap } from "lit-html/directives/class-map";
import secondsToDuration from "../../common/datetime/seconds_to_duration"; import secondsToDuration from "../../common/datetime/seconds_to_duration";
import { computeStateDisplay } from "../../common/entity/compute_state_display"; import { computeStateDisplay } from "../../common/entity/compute_state_display";
import { computeStateDomain } from "../../common/entity/compute_state_domain"; import { computeStateDomain } from "../../common/entity/compute_state_domain";

View File

@@ -1,4 +1,5 @@
import type { HassEntity } from "home-assistant-js-websocket"; import type { HassEntity } from "home-assistant-js-websocket";
import { styleMap } from "lit-html/directives/style-map";
import { import {
css, css,
CSSResult, CSSResult,
@@ -6,17 +7,15 @@ import {
LitElement, LitElement,
property, property,
PropertyValues, PropertyValues,
query,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { ifDefined } from "lit-html/directives/if-defined.js"; import { ifDefined } from "lit-html/directives/if-defined";
import { computeActiveState } from "../../common/entity/compute_active_state"; import { computeActiveState } from "../../common/entity/compute_active_state";
import { computeStateDomain } from "../../common/entity/compute_state_domain"; import { computeStateDomain } from "../../common/entity/compute_state_domain";
import { stateIcon } from "../../common/entity/state_icon"; import { stateIcon } from "../../common/entity/state_icon";
import { iconColorCSS } from "../../common/style/icon_color_css"; import { iconColorCSS } from "../../common/style/icon_color_css";
import type { HomeAssistant } from "../../types"; import type { HomeAssistant } from "../../types";
import "../ha-icon"; import "../ha-icon";
import type { HaIcon } from "../ha-icon";
export class StateBadge extends LitElement { export class StateBadge extends LitElement {
public hass?: HomeAssistant; public hass?: HomeAssistant;
@@ -29,12 +28,15 @@ export class StateBadge extends LitElement {
@property({ type: Boolean }) public stateColor?: boolean; @property({ type: Boolean }) public stateColor?: boolean;
@query("ha-icon") private _icon!: HaIcon; @property({ type: Boolean, reflect: true, attribute: "icon" })
private _showIcon = true;
@property() private _iconStyle: { [name: string]: string } = {};
protected render(): TemplateResult { protected render(): TemplateResult {
const stateObj = this.stateObj; const stateObj = this.stateObj;
if (!stateObj) { if (!stateObj || !this._showIcon) {
return html``; return html``;
} }
@@ -42,7 +44,7 @@ export class StateBadge extends LitElement {
return html` return html`
<ha-icon <ha-icon
id="icon" style=${styleMap(this._iconStyle)}
data-domain=${ifDefined( data-domain=${ifDefined(
this.stateColor || (domain === "light" && this.stateColor !== false) this.stateColor || (domain === "light" && this.stateColor !== false)
? domain ? domain
@@ -60,14 +62,13 @@ export class StateBadge extends LitElement {
} }
const stateObj = this.stateObj; const stateObj = this.stateObj;
const iconStyle: Partial<CSSStyleDeclaration> = { const iconStyle: { [name: string]: string } = {};
color: "",
filter: "",
display: "",
};
const hostStyle: Partial<CSSStyleDeclaration> = { const hostStyle: Partial<CSSStyleDeclaration> = {
backgroundImage: "", backgroundImage: "",
}; };
this._showIcon = true;
if (stateObj) { if (stateObj) {
// hide icon if we have entity picture // hide icon if we have entity picture
if ( if (
@@ -79,7 +80,7 @@ export class StateBadge extends LitElement {
imageUrl = this.hass.hassUrl(imageUrl); imageUrl = this.hass.hassUrl(imageUrl);
} }
hostStyle.backgroundImage = `url(${imageUrl})`; hostStyle.backgroundImage = `url(${imageUrl})`;
iconStyle.display = "none"; this._showIcon = false;
} else if (stateObj.state === "on") { } else if (stateObj.state === "on") {
if (stateObj.attributes.hs_color && this.stateColor !== false) { if (stateObj.attributes.hs_color && this.stateColor !== false) {
const hue = stateObj.attributes.hs_color[0]; const hue = stateObj.attributes.hs_color[0];
@@ -102,7 +103,7 @@ export class StateBadge extends LitElement {
} }
} }
} }
Object.assign(this._icon.style, iconStyle); this._iconStyle = iconStyle;
Object.assign(this.style, hostStyle); Object.assign(this.style, hostStyle);
} }
@@ -119,8 +120,17 @@ export class StateBadge extends LitElement {
background-size: cover; background-size: cover;
line-height: 40px; line-height: 40px;
vertical-align: middle; vertical-align: middle;
box-sizing: border-box;
}
:host(:focus) {
outline: none;
}
:host(:not([icon]):focus) {
border: 2px solid var(--divider-color);
}
:host([icon]:focus) {
background: var(--divider-color);
} }
ha-icon { ha-icon {
transition: color 0.3s ease-in-out, filter 0.3s ease-in-out; transition: color 0.3s ease-in-out, filter 0.3s ease-in-out;
} }

View File

@@ -1,6 +1,6 @@
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { computeStateName } from "../../common/entity/compute_state_name"; import { computeStateName } from "../../common/entity/compute_state_name";
import { computeRTL } from "../../common/util/compute_rtl"; import { computeRTL } from "../../common/util/compute_rtl";
import "../ha-relative-time"; import "../ha-relative-time";

View File

@@ -1,9 +1,9 @@
import "./ha-icon-button"; import "./ha-icon-button";
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import "@polymer/paper-item/paper-item.js"; import "@polymer/paper-item/paper-item";
import "@polymer/paper-item/paper-item-body.js"; import "@polymer/paper-item/paper-item-body";
import "@polymer/paper-listbox"; import "@polymer/paper-listbox/paper-listbox";
import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light.js"; import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light";
import { UnsubscribeFunc } from "home-assistant-js-websocket"; import { UnsubscribeFunc } from "home-assistant-js-websocket";
import { import {
css, css,

View File

@@ -8,7 +8,7 @@ import {
property, property,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { until } from "lit-html/directives/until.js"; import { until } from "lit-html/directives/until";
import hassAttributeUtil from "../util/hass-attributes-util"; import hassAttributeUtil from "../util/hass-attributes-util";
let jsYamlPromise: Promise<typeof import("js-yaml")>; let jsYamlPromise: Promise<typeof import("js-yaml")>;

View File

@@ -6,18 +6,19 @@ import {
CSSResult, CSSResult,
css, css,
query, query,
property,
} from "lit-element"; } from "lit-element";
import "@material/mwc-button"; import "@material/mwc-button";
import "@material/mwc-menu"; import "@material/mwc-menu";
import "@material/mwc-list/mwc-list-item.js"; import "@material/mwc-list/mwc-list-item";
import type { Menu } from "@material/mwc-menu"; import type { Menu, Corner } from "@material/mwc-menu";
import { haStyle } from "../resources/styles";
import "./ha-icon-button"; import "./ha-icon-button";
@customElement("ha-button-menu") @customElement("ha-button-menu")
export class HaButtonMenu extends LitElement { export class HaButtonMenu extends LitElement {
@property() public corner: Corner = "TOP_START";
@query("mwc-menu") private _menu?: Menu; @query("mwc-menu") private _menu?: Menu;
protected render(): TemplateResult { protected render(): TemplateResult {
@@ -25,7 +26,7 @@ export class HaButtonMenu extends LitElement {
<div @click=${this._handleClick}> <div @click=${this._handleClick}>
<slot name="trigger"></slot> <slot name="trigger"></slot>
</div> </div>
<mwc-menu> <mwc-menu .corner=${this.corner}>
<slot></slot> <slot></slot>
</mwc-menu> </mwc-menu>
`; `;
@@ -36,15 +37,13 @@ export class HaButtonMenu extends LitElement {
this._menu!.show(); this._menu!.show();
} }
static get styles(): CSSResult[] { static get styles(): CSSResult {
return [ return css`
haStyle, :host {
css` display: block;
:host { position: relative;
position: relative; }
} `;
`,
];
} }
} }

View File

@@ -1,7 +1,6 @@
import "@material/mwc-checkbox"; import "@material/mwc-checkbox";
import type { Checkbox } from "@material/mwc-checkbox"; import type { Checkbox } from "@material/mwc-checkbox";
import { style } from "@material/mwc-checkbox/mwc-checkbox-css.js"; import { customElement } from "lit-element";
import { css, CSSResult, customElement } from "lit-element";
import type { Constructor } from "../types"; import type { Constructor } from "../types";
const MwcCheckbox = customElements.get("mwc-checkbox") as Constructor<Checkbox>; const MwcCheckbox = customElements.get("mwc-checkbox") as Constructor<Checkbox>;
@@ -12,18 +11,6 @@ export class HaCheckbox extends MwcCheckbox {
super.firstUpdated(); super.firstUpdated();
this.style.setProperty("--mdc-theme-secondary", "var(--primary-color)"); this.style.setProperty("--mdc-theme-secondary", "var(--primary-color)");
} }
protected static get styles(): CSSResult[] {
return [
style,
css`
.mdc-checkbox__native-control:enabled:not(:checked):not(:indeterminate)
~ .mdc-checkbox__background {
border-color: rgba(var(--rgb-primary-text-color), 0.54);
}
`,
];
}
} }
declare global { declare global {

View File

@@ -1,6 +1,6 @@
// @ts-ignore // @ts-ignore
import chipStyles from "@material/chips/dist/mdc.chips.min.css"; import chipStyles from "@material/chips/dist/mdc.chips.min.css";
import { ripple } from "@material/mwc-ripple/ripple-directive.js"; import { ripple } from "@material/mwc-ripple/ripple-directive";
import { import {
css, css,
CSSResult, CSSResult,

View File

@@ -1,8 +1,8 @@
import "@polymer/iron-flex-layout/iron-flex-layout-classes.js"; import "@polymer/iron-flex-layout/iron-flex-layout-classes";
import "./ha-icon-button"; import "./ha-icon-button";
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { EventsMixin } from "../mixins/events-mixin"; import { EventsMixin } from "../mixins/events-mixin";
/* /*

View File

@@ -1,6 +1,6 @@
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { CLIMATE_PRESET_NONE } from "../data/climate"; import { CLIMATE_PRESET_NONE } from "../data/climate";
import LocalizeMixin from "../mixins/localize-mixin"; import LocalizeMixin from "../mixins/localize-mixin";

View File

@@ -1,6 +1,6 @@
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { EventsMixin } from "../mixins/events-mixin"; import { EventsMixin } from "../mixins/events-mixin";
/** /**

View File

@@ -1,10 +1,10 @@
import "./ha-icon-button"; import "./ha-icon-button";
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import "@polymer/paper-item/paper-item.js"; import "@polymer/paper-item/paper-item";
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light.js"; import "@vaadin/vaadin-combo-box/theme/material/vaadin-combo-box-light";
import { EventsMixin } from "../mixins/events-mixin"; import { EventsMixin } from "../mixins/events-mixin";
class HaComboBox extends EventsMixin(PolymerElement) { class HaComboBox extends EventsMixin(PolymerElement) {
@@ -12,8 +12,7 @@ class HaComboBox extends EventsMixin(PolymerElement) {
return html` return html`
<style> <style>
paper-input > ha-icon-button { paper-input > ha-icon-button {
width: 24px; --mdc-icon-button-size: 24px;
height: 24px;
padding: 2px; padding: 2px;
color: var(--secondary-text-color); color: var(--secondary-text-color);
} }

View File

@@ -1,7 +1,7 @@
import "./ha-icon-button"; import "./ha-icon-button";
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { UNAVAILABLE } from "../data/entity"; import { UNAVAILABLE } from "../data/entity";
import CoverEntity from "../util/cover-model"; import CoverEntity from "../util/cover-model";
@@ -30,7 +30,7 @@ class HaCoverControls extends PolymerElement {
icon="hass:stop" icon="hass:stop"
on-click="onStopTap" on-click="onStopTap"
invisible$="[[!entityObj.supportsStop]]" invisible$="[[!entityObj.supportsStop]]"
disabled="[[computStopDisabled(stateObj)]]" disabled="[[computeStopDisabled(stateObj)]]"
></ha-icon-button> ></ha-icon-button>
<ha-icon-button <ha-icon-button
aria-label="Close cover" aria-label="Close cover"

View File

@@ -1,8 +1,8 @@
import "@polymer/iron-flex-layout/iron-flex-layout-classes.js"; import "@polymer/iron-flex-layout/iron-flex-layout-classes";
import "./ha-icon-button"; import "./ha-icon-button";
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import { UNAVAILABLE } from "../data/entity"; import { UNAVAILABLE } from "../data/entity";
import CoverEntity from "../util/cover-model"; import CoverEntity from "../util/cover-model";
@@ -31,7 +31,7 @@ class HaCoverTiltControls extends PolymerElement {
icon="hass:stop" icon="hass:stop"
on-click="onStopTiltTap" on-click="onStopTiltTap"
invisible$="[[!entityObj.supportsStopTilt]]" invisible$="[[!entityObj.supportsStopTilt]]"
disabled="[[computStopDisabled(stateObj)]]" disabled="[[computeStopDisabled(stateObj)]]"
title="Stop tilt" title="Stop tilt"
></ha-icon-button> ></ha-icon-button>
<ha-icon-button <ha-icon-button

View File

@@ -1,5 +1,5 @@
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import type { PaperInputElement } from "@polymer/paper-input/paper-input.js"; import type { PaperInputElement } from "@polymer/paper-input/paper-input";
import { import {
css, css,
customElement, customElement,

View File

@@ -1,6 +1,6 @@
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import "./ha-label-badge"; import "./ha-label-badge";
class HaDemoBadge extends PolymerElement { class HaDemoBadge extends PolymerElement {

View File

@@ -1,20 +1,22 @@
import "@material/mwc-dialog"; import "@material/mwc-dialog";
import type { Dialog } from "@material/mwc-dialog"; import type { Dialog } from "@material/mwc-dialog";
import { style } from "@material/mwc-dialog/mwc-dialog-css.js"; import { style } from "@material/mwc-dialog/mwc-dialog-css";
import "./ha-icon-button"; import "./ha-icon-button";
import { css, CSSResult, customElement, html } from "lit-element"; import { css, CSSResult, customElement, html } from "lit-element";
import type { Constructor, HomeAssistant } from "../types"; import type { Constructor, HomeAssistant } from "../types";
import { mdiClose } from "@mdi/js";
const MwcDialog = customElements.get("mwc-dialog") as Constructor<Dialog>; const MwcDialog = customElements.get("mwc-dialog") as Constructor<Dialog>;
export const createCloseHeading = (hass: HomeAssistant, title: string) => html` export const createCloseHeading = (hass: HomeAssistant, title: string) => html`
${title} ${title}
<ha-icon-button <mwc-icon-button
aria-label=${hass.localize("ui.dialogs.generic.close")} aria-label=${hass.localize("ui.dialogs.generic.close")}
icon="hass:close"
dialogAction="close" dialogAction="close"
class="close_button" class="close_button"
></ha-icon-button> >
<ha-svg-icon path=${mdiClose}></ha-svg-icon>
</mwc-icon-button>
`; `;
@customElement("ha-dialog") @customElement("ha-dialog")

View File

@@ -1,41 +0,0 @@
import "@material/mwc-fab";
import type { Fab } from "@material/mwc-fab";
import { ripple } from "@material/mwc-ripple/ripple-directive.js";
import { customElement, html, TemplateResult } from "lit-element";
import { classMap } from "lit-html/directives/class-map.js";
import type { Constructor } from "../types";
import "./ha-icon";
const MwcFab = customElements.get("mwc-fab") as Constructor<Fab>;
@customElement("ha-fab")
export class HaFab extends MwcFab {
// We override the render method because we don't have an icon font and mwc-fab doesn't support our svg-icon sets.
// Based on version mwc-fab 0.8
protected render(): TemplateResult {
const classes = {
"mdc-fab--mini": this.mini,
"mdc-fab--exited": this.exited,
"mdc-fab--extended": this.extended,
};
const showLabel = this.label !== "" && this.extended;
return html`
<button
.ripple="${ripple()}"
class="mdc-fab ${classMap(classes)}"
?disabled="${this.disabled}"
aria-label="${this.label || this.icon}"
>
${showLabel && this.showIconAtEnd ? this.label : ""}
${this.icon ? html` <ha-icon .icon=${this.icon}></ha-icon> ` : ""}
${showLabel && !this.showIconAtEnd ? this.label : ""}
</button>
`;
}
}
declare global {
interface HTMLElementTagNameMap {
"ha-fab": HaFab;
}
}

View File

@@ -1,5 +1,5 @@
import "@polymer/paper-checkbox"; import "@polymer/paper-checkbox/paper-checkbox";
import type { PaperCheckboxElement } from "@polymer/paper-checkbox"; import type { PaperCheckboxElement } from "@polymer/paper-checkbox/paper-checkbox";
import { import {
css, css,
CSSResult, CSSResult,

View File

@@ -1,5 +1,5 @@
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import type { PaperInputElement } from "@polymer/paper-input/paper-input.js"; import type { PaperInputElement } from "@polymer/paper-input/paper-input";
import { import {
customElement, customElement,
html, html,

View File

@@ -1,7 +1,7 @@
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import type { PaperInputElement } from "@polymer/paper-input/paper-input.js"; import type { PaperInputElement } from "@polymer/paper-input/paper-input";
import "@polymer/paper-slider"; import "@polymer/paper-slider/paper-slider";
import type { PaperSliderElement } from "@polymer/paper-slider"; import type { PaperSliderElement } from "@polymer/paper-slider/paper-slider";
import { import {
css, css,
CSSResult, CSSResult,

View File

@@ -1,9 +1,9 @@
import "@polymer/paper-checkbox"; import "@polymer/paper-checkbox/paper-checkbox";
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import "@polymer/paper-item/paper-icon-item.js"; import "@polymer/paper-item/paper-icon-item";
import "@polymer/paper-listbox"; import "@polymer/paper-listbox/paper-listbox";
import "@polymer/paper-menu-button"; import "@polymer/paper-menu-button/paper-menu-button";
import "@polymer/paper-ripple"; import "@polymer/paper-ripple/paper-ripple";
import { import {
css, css,
CSSResult, CSSResult,

View File

@@ -1,6 +1,6 @@
import "@polymer/paper-dropdown-menu/paper-dropdown-menu.js"; import "@polymer/paper-dropdown-menu/paper-dropdown-menu";
import "@polymer/paper-item/paper-item.js"; import "@polymer/paper-item/paper-item";
import "@polymer/paper-listbox"; import "@polymer/paper-listbox/paper-listbox";
import { import {
css, css,
CSSResult, CSSResult,

View File

@@ -1,6 +1,6 @@
import "../ha-icon-button"; import "../ha-icon-button";
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import type { PaperInputElement } from "@polymer/paper-input/paper-input.js"; import type { PaperInputElement } from "@polymer/paper-input/paper-input";
import { import {
customElement, customElement,
html, html,

View File

@@ -1,17 +1,30 @@
import { HaIconButton } from "./ha-icon-button"; import { LitElement, property, TemplateResult, html } from "lit-element";
import { mdiArrowLeft, mdiArrowRight } from "@mdi/js";
import "@material/mwc-icon-button/mwc-icon-button";
import "./ha-svg-icon";
export class HaIconButtonArrowPrev extends LitElement {
@property({ type: Boolean }) public disabled = false;
@property() private _icon = mdiArrowLeft;
export class HaIconButtonArrowPrev extends HaIconButton {
public connectedCallback() { public connectedCallback() {
super.connectedCallback(); super.connectedCallback();
// wait to check for direction since otherwise direction is wrong even though top level is RTL // wait to check for direction since otherwise direction is wrong even though top level is RTL
setTimeout(() => { setTimeout(() => {
this.icon = this._icon =
window.getComputedStyle(this).direction === "ltr" window.getComputedStyle(this).direction === "ltr"
? "hass:arrow-left" ? mdiArrowLeft
: "hass:arrow-right"; : mdiArrowRight;
}, 100); }, 100);
} }
protected render(): TemplateResult {
return html`<mwc-icon-button .disabled=${this.disabled}>
<ha-svg-icon .path=${this._icon}></ha-svg-icon>
</mwc-icon-button> `;
}
} }
declare global { declare global {

View File

@@ -48,6 +48,7 @@ export class HaIconButton extends LitElement {
} }
mwc-icon-button { mwc-icon-button {
--mdc-theme-on-primary: currentColor; --mdc-theme-on-primary: currentColor;
--mdc-theme-text-disabled-on-light: var(--disabled-text-color);
} }
ha-icon { ha-icon {
--ha-icon-display: inline; --ha-icon-display: inline;

View File

@@ -1,4 +1,4 @@
import "@polymer/paper-input/paper-input.js"; import "@polymer/paper-input/paper-input";
import { import {
css, css,
customElement, customElement,

View File

@@ -1,5 +1,4 @@
import "@polymer/iron-icon"; import "@polymer/iron-icon/iron-icon";
import { get, set, clear, Store } from "idb-keyval";
import { import {
customElement, customElement,
LitElement, LitElement,
@@ -11,84 +10,23 @@ import {
CSSResult, CSSResult,
} from "lit-element"; } from "lit-element";
import "./ha-svg-icon"; import "./ha-svg-icon";
import { customIconsets, CustomIcon } from "../data/custom_iconsets";
import {
Chunks,
MDI_PREFIXES,
getIcon,
findIconChunk,
Icons,
checkCacheVersion,
writeCache,
} from "../data/iconsets";
import { debounce } from "../common/util/debounce"; import { debounce } from "../common/util/debounce";
import { iconMetadata } from "../resources/icon-metadata";
import { IconMeta } from "../types";
interface Icons {
[key: string]: string;
}
interface Chunks {
[key: string]: Promise<Icons>;
}
const iconStore = new Store("hass-icon-db", "mdi-icon-store");
get("_version", iconStore).then((version) => {
if (!version) {
set("_version", iconMetadata.version, iconStore);
} else if (version !== iconMetadata.version) {
clear(iconStore).then(() =>
set("_version", iconMetadata.version, iconStore)
);
}
});
const chunks: Chunks = {}; const chunks: Chunks = {};
const MDI_PREFIXES = ["mdi", "hass", "hassio", "hademo"];
let toRead: Array<[string, (string) => void]> = []; checkCacheVersion();
// Queue up as many icon fetches in 1 transaction const debouncedWriteCache = debounce(() => writeCache(chunks), 2000);
const getIcon = (iconName: string) =>
new Promise<string>((resolve) => {
toRead.push([iconName, resolve]);
if (toRead.length > 1) {
return;
}
const results: Array<[(string) => void, IDBRequest]> = [];
iconStore
._withIDBStore("readonly", (store) => {
for (const [iconName_, resolve_] of toRead) {
results.push([resolve_, store.get(iconName_)]);
}
toRead = [];
})
.then(() => {
for (const [resolve_, request] of results) {
resolve_(request.result);
}
});
});
const findIconChunk = (icon): string => {
let lastChunk: IconMeta;
for (const chunk of iconMetadata.parts) {
if (chunk.start !== undefined && icon < chunk.start) {
break;
}
lastChunk = chunk;
}
return lastChunk!.file;
};
const debouncedWriteCache = debounce(async () => {
const keys = Object.keys(chunks);
const iconsSets: Icons[] = await Promise.all(Object.values(chunks));
// We do a batch opening the store just once, for (considerable) performance
iconStore._withIDBStore("readwrite", (store) => {
iconsSets.forEach((icons, idx) => {
Object.entries(icons).forEach(([name, path]) => {
store.put(path, name);
});
delete chunks[keys[idx]];
});
});
}, 2000);
@customElement("ha-icon") @customElement("ha-icon")
export class HaIcon extends LitElement { export class HaIcon extends LitElement {
@@ -96,11 +34,14 @@ export class HaIcon extends LitElement {
@property() private _path?: string; @property() private _path?: string;
@property() private _noMdi = false; @property() private _viewBox?;
@property() private _legacy = false;
protected updated(changedProps: PropertyValues) { protected updated(changedProps: PropertyValues) {
if (changedProps.has("icon")) { if (changedProps.has("icon")) {
this._path = undefined; this._path = undefined;
this._viewBox = undefined;
this._loadIcon(); this._loadIcon();
} }
} }
@@ -109,25 +50,39 @@ export class HaIcon extends LitElement {
if (!this.icon) { if (!this.icon) {
return html``; return html``;
} }
if (this._noMdi) { if (this._legacy) {
return html`<iron-icon .icon=${this.icon}></iron-icon>`; return html`<iron-icon .icon=${this.icon}></iron-icon>`;
} }
return html`<ha-svg-icon .path=${this._path}></ha-svg-icon>`; return html`<ha-svg-icon
.path=${this._path}
.viewBox=${this._viewBox}
></ha-svg-icon>`;
} }
private async _loadIcon() { private async _loadIcon() {
if (!this.icon) { if (!this.icon) {
return; return;
} }
const icon = this.icon.split(":", 2); const [iconPrefix, iconName] = this.icon.split(":", 2);
if (!MDI_PREFIXES.includes(icon[0])) {
this._noMdi = true; if (!iconPrefix || !iconName) {
return; return;
} }
this._noMdi = false; if (!MDI_PREFIXES.includes(iconPrefix)) {
if (iconPrefix in customIconsets) {
const customIconset = customIconsets[iconPrefix];
if (customIconset) {
this._setCustomPath(customIconset(iconName));
}
return;
}
this._legacy = true;
return;
}
this._legacy = false;
const iconName = icon[1];
const cachedPath: string = await getIcon(iconName); const cachedPath: string = await getIcon(iconName);
if (cachedPath) { if (cachedPath) {
this._path = cachedPath; this._path = cachedPath;
@@ -147,6 +102,12 @@ export class HaIcon extends LitElement {
debouncedWriteCache(); debouncedWriteCache();
} }
private async _setCustomPath(promise: Promise<CustomIcon>) {
const icon = await promise;
this._path = icon.path;
this._viewBox = icon.viewBox;
}
private async _setPath(promise: Promise<Icons>, iconName: string) { private async _setPath(promise: Promise<Icons>, iconName: string) {
const iconPack = await promise; const iconPack = await promise;
this._path = iconPack[iconName]; this._path = iconPack[iconName];

View File

@@ -7,7 +7,7 @@ import {
PropertyValues, PropertyValues,
TemplateResult, TemplateResult,
} from "lit-element"; } from "lit-element";
import { classMap } from "lit-html/directives/class-map.js"; import { classMap } from "lit-html/directives/class-map";
import "./ha-icon"; import "./ha-icon";
class HaLabelBadge extends LitElement { class HaLabelBadge extends LitElement {
@@ -31,12 +31,14 @@ class HaLabelBadge extends LitElement {
big: Boolean(this.value && this.value.length > 4), big: Boolean(this.value && this.value.length > 4),
})}" })}"
> >
${this.icon && !this.value && !this.image <slot>
? html` <ha-icon .icon="${this.icon}"></ha-icon> ` ${this.icon && !this.value && !this.image
: ""} ? html` <ha-icon .icon=${this.icon}></ha-icon> `
${this.value && !this.image : ""}
? html` <span>${this.value}</span> ` ${this.value && !this.image
: ""} ? html` <span>${this.value}</span> `
: ""}
</slot>
</div> </div>
${this.label ${this.label
? html` ? html`

View File

@@ -1,6 +1,6 @@
import { html } from "@polymer/polymer/lib/utils/html-tag.js"; import { html } from "@polymer/polymer/lib/utils/html-tag";
/* eslint-plugin-disable lit */ /* eslint-plugin-disable lit */
import { PolymerElement } from "@polymer/polymer/polymer-element.js"; import { PolymerElement } from "@polymer/polymer/polymer-element";
import "./ha-icon"; import "./ha-icon";
import "./ha-paper-slider"; import "./ha-paper-slider";

View File

@@ -13,6 +13,7 @@ import { computeDomain } from "../common/entity/compute_domain";
import { subscribeNotifications } from "../data/persistent_notification"; import { subscribeNotifications } from "../data/persistent_notification";
import { HomeAssistant } from "../types"; import { HomeAssistant } from "../types";
import "./ha-icon-button"; import "./ha-icon-button";
import { mdiMenu } from "@mdi/js";
@customElement("ha-menu-button") @customElement("ha-menu-button")
class HaMenuButton extends LitElement { class HaMenuButton extends LitElement {
@@ -55,11 +56,12 @@ class HaMenuButton extends LitElement {
(entityId) => computeDomain(entityId) === "configurator" (entityId) => computeDomain(entityId) === "configurator"
)); ));
return html` return html`
<ha-icon-button <mwc-icon-button
aria-label=${this.hass.localize("ui.sidebar.sidebar_toggle")} aria-label=${this.hass.localize("ui.sidebar.sidebar_toggle")}
icon="hass:menu"
@click=${this._toggleMenu} @click=${this._toggleMenu}
></ha-icon-button> >
<ha-svg-icon path=${mdiMenu}></ha-svg-icon>
</mwc-icon-button>
${hasNotifications ? html` <div class="dot"></div> ` : ""} ${hasNotifications ? html` <div class="dot"></div> ` : ""}
`; `;
} }
@@ -133,8 +135,8 @@ class HaMenuButton extends LitElement {
background-color: var(--accent-color); background-color: var(--accent-color);
width: 12px; width: 12px;
height: 12px; height: 12px;
top: 5px; top: 9px;
right: 2px; right: 7px;
border-radius: 50%; border-radius: 50%;
border: 2px solid var(--app-header-background-color); border: 2px solid var(--app-header-background-color);
} }

View File

@@ -1,4 +1,4 @@
import "@polymer/paper-dropdown-menu/paper-dropdown-menu.js"; import "@polymer/paper-dropdown-menu/paper-dropdown-menu";
import { PolymerElement } from "@polymer/polymer"; import { PolymerElement } from "@polymer/polymer";
import { Constructor } from "../types"; import { Constructor } from "../types";

View File

@@ -1,4 +1,4 @@
import "@polymer/paper-slider"; import "@polymer/paper-slider/paper-slider";
/** /**
* @polymer * @polymer

Some files were not shown because too many files have changed in this diff Show More