mirror of
https://github.com/home-assistant/frontend.git
synced 2025-08-20 06:39:27 +00:00
Compare commits
45 Commits
add-suppor
...
int2
Author | SHA1 | Date | |
---|---|---|---|
![]() |
d154872955 | ||
![]() |
555f0dbc81 | ||
![]() |
076c58acea | ||
![]() |
c873ea0bf8 | ||
![]() |
73b49642f8 | ||
![]() |
cfdbad504c | ||
![]() |
26730cb2e2 | ||
![]() |
a77589922c | ||
![]() |
545f81fa24 | ||
![]() |
265ca40df1 | ||
![]() |
58cb775627 | ||
![]() |
945d992884 | ||
![]() |
574396f369 | ||
![]() |
42d3adad26 | ||
![]() |
7923c172ff | ||
![]() |
ced00a4945 | ||
![]() |
9c2a72d240 | ||
![]() |
89c2db1f8e | ||
![]() |
6ba31da4a5 | ||
![]() |
1c516822a5 | ||
![]() |
be741feb2a | ||
![]() |
72605051e4 | ||
![]() |
9f9ab6c238 | ||
![]() |
1e4a3c398b | ||
![]() |
690e2a3aa9 | ||
![]() |
e1d17f3d3a | ||
![]() |
45316b458f | ||
![]() |
51a69f1042 | ||
![]() |
e4ebb320e5 | ||
![]() |
e9c5e51f25 | ||
![]() |
4091205b58 | ||
![]() |
478539d58d | ||
![]() |
d57cf65edc | ||
![]() |
21f58356bd | ||
![]() |
79cb7bda04 | ||
![]() |
ec844560af | ||
![]() |
c467ef82ea | ||
![]() |
bdcd1a0a88 | ||
![]() |
36710d7588 | ||
![]() |
c1e905e03a | ||
![]() |
87d781f786 | ||
![]() |
c34e845886 | ||
![]() |
412587a457 | ||
![]() |
5b3a13f8d4 | ||
![]() |
1ec5172370 |
@@ -1,5 +1,5 @@
|
|||||||
# See here for image contents: https://github.com/microsoft/vscode-dev-containers/tree/v0.148.1/containers/python-3/.devcontainer/base.Dockerfile
|
# See here for image contents: https://github.com/microsoft/vscode-dev-containers/tree/v0.148.1/containers/python-3/.devcontainer/base.Dockerfile
|
||||||
FROM mcr.microsoft.com/vscode/devcontainers/python:0-3.10
|
FROM mcr.microsoft.com/vscode/devcontainers/python:0-3.9
|
||||||
|
|
||||||
ENV \
|
ENV \
|
||||||
DEBIAN_FRONTEND=noninteractive \
|
DEBIAN_FRONTEND=noninteractive \
|
||||||
|
@@ -5,7 +5,6 @@
|
|||||||
"plugin:@typescript-eslint/recommended",
|
"plugin:@typescript-eslint/recommended",
|
||||||
"plugin:wc/recommended",
|
"plugin:wc/recommended",
|
||||||
"plugin:lit/all",
|
"plugin:lit/all",
|
||||||
"plugin:lit-a11y/recommended",
|
|
||||||
"prettier"
|
"prettier"
|
||||||
],
|
],
|
||||||
"parser": "@typescript-eslint/parser",
|
"parser": "@typescript-eslint/parser",
|
||||||
@@ -20,7 +19,7 @@
|
|||||||
"settings": {
|
"settings": {
|
||||||
"import/resolver": {
|
"import/resolver": {
|
||||||
"webpack": {
|
"webpack": {
|
||||||
"config": "./webpack.config.cjs"
|
"config": "./webpack.config.js"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -66,10 +65,7 @@
|
|||||||
"import/extensions": [
|
"import/extensions": [
|
||||||
"error",
|
"error",
|
||||||
"ignorePackages",
|
"ignorePackages",
|
||||||
{
|
{ "ts": "never", "js": "never" }
|
||||||
"ts": "never",
|
|
||||||
"js": "never"
|
|
||||||
}
|
|
||||||
],
|
],
|
||||||
"no-restricted-syntax": ["error", "LabeledStatement", "WithStatement"],
|
"no-restricted-syntax": ["error", "LabeledStatement", "WithStatement"],
|
||||||
"object-curly-newline": "off",
|
"object-curly-newline": "off",
|
||||||
@@ -116,14 +112,7 @@
|
|||||||
],
|
],
|
||||||
"unused-imports/no-unused-imports": "error",
|
"unused-imports/no-unused-imports": "error",
|
||||||
"lit/attribute-value-entities": "off",
|
"lit/attribute-value-entities": "off",
|
||||||
"lit/no-template-map": "off",
|
"lit/no-template-map": "off"
|
||||||
"lit/no-native-attributes": "warn",
|
|
||||||
"lit/no-this-assign-in-render": "warn",
|
|
||||||
"lit-a11y/click-events-have-key-events": ["off"],
|
|
||||||
"lit-a11y/no-autofocus": "off",
|
|
||||||
"lit-a11y/alt-text": "warn",
|
|
||||||
"lit-a11y/anchor-is-valid": "warn",
|
|
||||||
"lit-a11y/role-has-required-aria-attrs": "warn"
|
|
||||||
},
|
},
|
||||||
"plugins": ["disable", "unused-imports"],
|
"plugins": ["disable", "unused-imports"],
|
||||||
"processor": "disable/disable"
|
"processor": "disable/disable"
|
||||||
|
6
.github/dependabot.yml
vendored
6
.github/dependabot.yml
vendored
@@ -6,3 +6,9 @@ updates:
|
|||||||
interval: weekly
|
interval: weekly
|
||||||
time: "06:00"
|
time: "06:00"
|
||||||
open-pull-requests-limit: 10
|
open-pull-requests-limit: 10
|
||||||
|
- package-ecosystem: "npm"
|
||||||
|
directory: "/"
|
||||||
|
schedule:
|
||||||
|
interval: "daily"
|
||||||
|
time: "06:00"
|
||||||
|
open-pull-requests-limit: 5
|
||||||
|
14
.github/workflows/cast_deployment.yaml
vendored
14
.github/workflows/cast_deployment.yaml
vendored
@@ -22,7 +22,7 @@ jobs:
|
|||||||
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
with:
|
with:
|
||||||
ref: dev
|
ref: dev
|
||||||
|
|
||||||
@@ -33,7 +33,9 @@ jobs:
|
|||||||
cache: yarn
|
cache: yarn
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
|
env:
|
||||||
|
CI: true
|
||||||
|
|
||||||
- name: Build Cast
|
- name: Build Cast
|
||||||
run: ./node_modules/.bin/gulp build-cast
|
run: ./node_modules/.bin/gulp build-cast
|
||||||
@@ -58,7 +60,7 @@ jobs:
|
|||||||
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
with:
|
with:
|
||||||
ref: master
|
ref: master
|
||||||
|
|
||||||
@@ -69,7 +71,9 @@ jobs:
|
|||||||
cache: yarn
|
cache: yarn
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
|
env:
|
||||||
|
CI: true
|
||||||
|
|
||||||
- name: Build Cast
|
- name: Build Cast
|
||||||
run: ./node_modules/.bin/gulp build-cast
|
run: ./node_modules/.bin/gulp build-cast
|
||||||
@@ -83,4 +87,4 @@ jobs:
|
|||||||
args: deploy --dir=cast/dist --prod
|
args: deploy --dir=cast/dist --prod
|
||||||
env:
|
env:
|
||||||
NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }}
|
NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }}
|
||||||
NETLIFY_SITE_ID: ${{ secrets.NETLIFY_CAST_SITE_ID }}
|
NETLIFY_SITE_ID: ${{ secrets.NETLIFY_CAST_SITE_ID }}
|
42
.github/workflows/ci.yaml
vendored
42
.github/workflows/ci.yaml
vendored
@@ -15,83 +15,83 @@ env:
|
|||||||
NODE_OPTIONS: --max_old_space_size=6144
|
NODE_OPTIONS: --max_old_space_size=6144
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
concurrency:
|
|
||||||
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
|
|
||||||
cancel-in-progress: true
|
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
lint:
|
lint:
|
||||||
name: Lint and check format
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
- name: Set up Node ${{ env.NODE_VERSION }}
|
- name: Set up Node ${{ env.NODE_VERSION }}
|
||||||
uses: actions/setup-node@v3.6.0
|
uses: actions/setup-node@v3.6.0
|
||||||
with:
|
with:
|
||||||
node-version: ${{ env.NODE_VERSION }}
|
node-version: ${{ env.NODE_VERSION }}
|
||||||
cache: yarn
|
cache: yarn
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
- name: Check for duplicate dependencies
|
env:
|
||||||
run: yarn dedupe --check
|
CI: true
|
||||||
- name: Build resources
|
- name: Build resources
|
||||||
run: ./node_modules/.bin/gulp gen-icons-json build-translations build-locale-data gather-gallery-pages
|
run: ./node_modules/.bin/gulp gen-icons-json build-translations build-locale-data gather-gallery-pages
|
||||||
- name: Run eslint
|
- name: Run eslint
|
||||||
run: yarn run lint:eslint --quiet
|
run: yarn run lint:eslint
|
||||||
- name: Run tsc
|
- name: Run tsc
|
||||||
run: yarn run lint:types
|
run: yarn run lint:types
|
||||||
- name: Run prettier
|
- name: Run prettier
|
||||||
run: yarn run lint:prettier
|
run: yarn run lint:prettier
|
||||||
|
- name: Check for duplicate dependencies
|
||||||
|
run: yarn dedupe --check
|
||||||
test:
|
test:
|
||||||
name: Run tests
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
- name: Set up Node ${{ env.NODE_VERSION }}
|
- name: Set up Node ${{ env.NODE_VERSION }}
|
||||||
uses: actions/setup-node@v3.6.0
|
uses: actions/setup-node@v3.6.0
|
||||||
with:
|
with:
|
||||||
node-version: ${{ env.NODE_VERSION }}
|
node-version: ${{ env.NODE_VERSION }}
|
||||||
cache: yarn
|
cache: yarn
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
|
env:
|
||||||
|
CI: true
|
||||||
- name: Build resources
|
- name: Build resources
|
||||||
run: ./node_modules/.bin/gulp build-translations build-locale-data
|
run: ./node_modules/.bin/gulp build-translations build-locale-data
|
||||||
- name: Run Tests
|
- name: Run Tests
|
||||||
run: yarn run test
|
run: yarn run test
|
||||||
build:
|
build:
|
||||||
name: Build frontend
|
|
||||||
needs: [lint, test]
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
needs: [lint, test]
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
- name: Set up Node ${{ env.NODE_VERSION }}
|
- name: Set up Node ${{ env.NODE_VERSION }}
|
||||||
uses: actions/setup-node@v3.6.0
|
uses: actions/setup-node@v3.6.0
|
||||||
with:
|
with:
|
||||||
node-version: ${{ env.NODE_VERSION }}
|
node-version: ${{ env.NODE_VERSION }}
|
||||||
cache: yarn
|
cache: yarn
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
|
env:
|
||||||
|
CI: true
|
||||||
- name: Build Application
|
- name: Build Application
|
||||||
run: ./node_modules/.bin/gulp build-app
|
run: ./node_modules/.bin/gulp build-app
|
||||||
env:
|
env:
|
||||||
IS_TEST: "true"
|
IS_TEST: "true"
|
||||||
supervisor:
|
supervisor:
|
||||||
name: Build supervisor
|
|
||||||
needs: [lint, test]
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
needs: [lint, test]
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
- name: Set up Node ${{ env.NODE_VERSION }}
|
- name: Set up Node ${{ env.NODE_VERSION }}
|
||||||
uses: actions/setup-node@v3.6.0
|
uses: actions/setup-node@v3.6.0
|
||||||
with:
|
with:
|
||||||
node-version: ${{ env.NODE_VERSION }}
|
node-version: ${{ env.NODE_VERSION }}
|
||||||
cache: yarn
|
cache: yarn
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
|
env:
|
||||||
|
CI: true
|
||||||
- name: Build Application
|
- name: Build Application
|
||||||
run: ./node_modules/.bin/gulp build-hassio
|
run: ./node_modules/.bin/gulp build-hassio
|
||||||
env:
|
env:
|
||||||
|
2
.github/workflows/codeql-analysis.yml
vendored
2
.github/workflows/codeql-analysis.yml
vendored
@@ -23,7 +23,7 @@ jobs:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
with:
|
with:
|
||||||
# We must fetch at least the immediate parents so that if this is
|
# We must fetch at least the immediate parents so that if this is
|
||||||
# a pull request then we can checkout the head.
|
# a pull request then we can checkout the head.
|
||||||
|
18
.github/workflows/demo_deployment.yaml
vendored
18
.github/workflows/demo_deployment.yaml
vendored
@@ -17,13 +17,13 @@ jobs:
|
|||||||
deploy_dev:
|
deploy_dev:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
name: Demo Development
|
name: Demo Development
|
||||||
if: github.event_name != 'push' || github.ref_name != 'master'
|
if: github.event_name != 'push' || github.ref != 'master'
|
||||||
environment:
|
environment:
|
||||||
name: Demo Development
|
name: Demo Development
|
||||||
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
with:
|
with:
|
||||||
ref: dev
|
ref: dev
|
||||||
|
|
||||||
@@ -34,7 +34,9 @@ jobs:
|
|||||||
cache: yarn
|
cache: yarn
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
|
env:
|
||||||
|
CI: true
|
||||||
|
|
||||||
- name: Build Demo
|
- name: Build Demo
|
||||||
run: ./node_modules/.bin/gulp build-demo
|
run: ./node_modules/.bin/gulp build-demo
|
||||||
@@ -53,13 +55,13 @@ jobs:
|
|||||||
deploy_master:
|
deploy_master:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
name: Demo Production
|
name: Demo Production
|
||||||
if: github.event_name == 'push' && github.ref_name == 'master'
|
if: github.event_name == 'push' && github.ref == 'master'
|
||||||
environment:
|
environment:
|
||||||
name: Demo Production
|
name: Demo Production
|
||||||
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
with:
|
with:
|
||||||
ref: master
|
ref: master
|
||||||
|
|
||||||
@@ -70,7 +72,9 @@ jobs:
|
|||||||
cache: yarn
|
cache: yarn
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
|
env:
|
||||||
|
CI: true
|
||||||
|
|
||||||
- name: Build Demo
|
- name: Build Demo
|
||||||
run: ./node_modules/.bin/gulp build-demo
|
run: ./node_modules/.bin/gulp build-demo
|
||||||
@@ -84,4 +88,4 @@ jobs:
|
|||||||
args: deploy --dir=demo/dist --prod
|
args: deploy --dir=demo/dist --prod
|
||||||
env:
|
env:
|
||||||
NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }}
|
NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }}
|
||||||
NETLIFY_SITE_ID: ${{ secrets.NETLIFY_DEMO_SITE_ID }}
|
NETLIFY_SITE_ID: ${{ secrets.NETLIFY_DEMO_SITE_ID }}
|
6
.github/workflows/design_deployment.yaml
vendored
6
.github/workflows/design_deployment.yaml
vendored
@@ -17,7 +17,7 @@ jobs:
|
|||||||
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
url: ${{ steps.deploy.outputs.NETLIFY_LIVE_URL || steps.deploy.outputs.NETLIFY_URL }}
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
|
|
||||||
- name: Set up Node ${{ env.NODE_VERSION }}
|
- name: Set up Node ${{ env.NODE_VERSION }}
|
||||||
uses: actions/setup-node@v3.6.0
|
uses: actions/setup-node@v3.6.0
|
||||||
@@ -26,7 +26,9 @@ jobs:
|
|||||||
cache: yarn
|
cache: yarn
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
|
env:
|
||||||
|
CI: true
|
||||||
|
|
||||||
- name: Build Gallery
|
- name: Build Gallery
|
||||||
run: ./node_modules/.bin/gulp build-gallery
|
run: ./node_modules/.bin/gulp build-gallery
|
||||||
|
6
.github/workflows/design_preview.yaml
vendored
6
.github/workflows/design_preview.yaml
vendored
@@ -22,7 +22,7 @@ jobs:
|
|||||||
if: github.repository == 'home-assistant/frontend' && contains(github.event.pull_request.labels.*.name, 'needs design preview')
|
if: github.repository == 'home-assistant/frontend' && contains(github.event.pull_request.labels.*.name, 'needs design preview')
|
||||||
steps:
|
steps:
|
||||||
- name: Check out files from GitHub
|
- name: Check out files from GitHub
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
|
|
||||||
- name: Set up Node ${{ env.NODE_VERSION }}
|
- name: Set up Node ${{ env.NODE_VERSION }}
|
||||||
uses: actions/setup-node@v3.6.0
|
uses: actions/setup-node@v3.6.0
|
||||||
@@ -31,7 +31,9 @@ jobs:
|
|||||||
cache: yarn
|
cache: yarn
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: yarn install --immutable
|
run: yarn install
|
||||||
|
env:
|
||||||
|
CI: true
|
||||||
|
|
||||||
- name: Build Gallery
|
- name: Build Gallery
|
||||||
run: ./node_modules/.bin/gulp build-gallery
|
run: ./node_modules/.bin/gulp build-gallery
|
||||||
|
4
.github/workflows/nightly.yaml
vendored
4
.github/workflows/nightly.yaml
vendored
@@ -21,7 +21,7 @@ jobs:
|
|||||||
contents: write
|
contents: write
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout the repository
|
- name: Checkout the repository
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
|
|
||||||
- name: Set up Python ${{ env.PYTHON_VERSION }}
|
- name: Set up Python ${{ env.PYTHON_VERSION }}
|
||||||
uses: actions/setup-python@v4
|
uses: actions/setup-python@v4
|
||||||
@@ -43,7 +43,7 @@ jobs:
|
|||||||
LOKALISE_TOKEN: ${{ secrets.LOKALISE_TOKEN }}
|
LOKALISE_TOKEN: ${{ secrets.LOKALISE_TOKEN }}
|
||||||
|
|
||||||
- name: Bump version
|
- name: Bump version
|
||||||
run: script/version_bump.cjs nightly
|
run: script/version_bump.js nightly
|
||||||
|
|
||||||
- name: Build nightly Python wheels
|
- name: Build nightly Python wheels
|
||||||
run: |
|
run: |
|
||||||
|
2
.github/workflows/release.yaml
vendored
2
.github/workflows/release.yaml
vendored
@@ -24,7 +24,7 @@ jobs:
|
|||||||
contents: write # Required to upload release assets
|
contents: write # Required to upload release assets
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout the repository
|
- name: Checkout the repository
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
|
|
||||||
- name: Verify version
|
- name: Verify version
|
||||||
uses: home-assistant/actions/helpers/verify-version@master
|
uses: home-assistant/actions/helpers/verify-version@master
|
||||||
|
2
.github/workflows/stale.yml
vendored
2
.github/workflows/stale.yml
vendored
@@ -10,7 +10,7 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: 90 days stale policy
|
- name: 90 days stale policy
|
||||||
uses: actions/stale@v8.0.0
|
uses: actions/stale@v7.0.0
|
||||||
with:
|
with:
|
||||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
days-before-stale: 90
|
days-before-stale: 90
|
||||||
|
2
.github/workflows/translations.yaml
vendored
2
.github/workflows/translations.yaml
vendored
@@ -16,7 +16,7 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout the repository
|
- name: Checkout the repository
|
||||||
uses: actions/checkout@v3.5.2
|
uses: actions/checkout@v3.3.0
|
||||||
|
|
||||||
- name: Upload Translations
|
- name: Upload Translations
|
||||||
run: |
|
run: |
|
||||||
|
29
.yarn/patches/@lit-labs/virtualizer/event-target-shim.patch
Normal file
29
.yarn/patches/@lit-labs/virtualizer/event-target-shim.patch
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
diff --git a/polyfillLoaders/EventTarget.js b/polyfillLoaders/EventTarget.js
|
||||||
|
index 4e18ade7ba485849f17f28c94c42f0e0e01ac387..8f34f4f646c7f7becc208fb5a546c96034fc74dc 100644
|
||||||
|
--- a/polyfillLoaders/EventTarget.js
|
||||||
|
+++ b/polyfillLoaders/EventTarget.js
|
||||||
|
@@ -6,16 +6,15 @@
|
||||||
|
let _ET;
|
||||||
|
let ET;
|
||||||
|
export default async function EventTarget() {
|
||||||
|
- return ET || init();
|
||||||
|
+ return ET || init();
|
||||||
|
}
|
||||||
|
async function init() {
|
||||||
|
- _ET = window.EventTarget;
|
||||||
|
- try {
|
||||||
|
- new _ET();
|
||||||
|
- }
|
||||||
|
- catch (_a) {
|
||||||
|
- _ET = (await import('event-target-shim')).EventTarget;
|
||||||
|
- }
|
||||||
|
- return (ET = _ET);
|
||||||
|
+ _ET = window.EventTarget;
|
||||||
|
+ try {
|
||||||
|
+ new _ET();
|
||||||
|
+ } catch (_a) {
|
||||||
|
+ _ET = (await import("event-target-shim")).default.EventTarget;
|
||||||
|
+ }
|
||||||
|
+ return (ET = _ET);
|
||||||
|
}
|
||||||
|
//# sourceMappingURL=EventTarget.js.map
|
566
.yarn/plugins/@yarnpkg/plugin-interactive-tools.cjs
vendored
566
.yarn/plugins/@yarnpkg/plugin-interactive-tools.cjs
vendored
File diff suppressed because one or more lines are too long
5
.yarn/plugins/@yarnpkg/plugin-typescript.cjs
vendored
5
.yarn/plugins/@yarnpkg/plugin-typescript.cjs
vendored
File diff suppressed because one or more lines are too long
783
.yarn/releases/yarn-3.2.3.cjs
vendored
Executable file
783
.yarn/releases/yarn-3.2.3.cjs
vendored
Executable file
File diff suppressed because one or more lines are too long
873
.yarn/releases/yarn-3.5.0.cjs
vendored
873
.yarn/releases/yarn-3.5.0.cjs
vendored
File diff suppressed because one or more lines are too long
@@ -1,5 +1,3 @@
|
|||||||
defaultSemverRangePrefix: ""
|
|
||||||
|
|
||||||
nodeLinker: node-modules
|
nodeLinker: node-modules
|
||||||
|
|
||||||
plugins:
|
plugins:
|
||||||
@@ -8,4 +6,4 @@ plugins:
|
|||||||
- path: .yarn/plugins/@yarnpkg/plugin-interactive-tools.cjs
|
- path: .yarn/plugins/@yarnpkg/plugin-interactive-tools.cjs
|
||||||
spec: "@yarnpkg/plugin-interactive-tools"
|
spec: "@yarnpkg/plugin-interactive-tools"
|
||||||
|
|
||||||
yarnPath: .yarn/releases/yarn-3.5.0.cjs
|
yarnPath: .yarn/releases/yarn-3.2.3.cjs
|
||||||
|
@@ -1,15 +1,6 @@
|
|||||||
const path = require("path");
|
const path = require("path");
|
||||||
const env = require("./env.cjs");
|
const env = require("./env.js");
|
||||||
const paths = require("./paths.cjs");
|
const paths = require("./paths.js");
|
||||||
|
|
||||||
// GitHub base URL to use for production source maps
|
|
||||||
// Nightly builds use the commit SHA, otherwise assumes there is a tag that matches the version
|
|
||||||
module.exports.sourceMapURL = () => {
|
|
||||||
const ref = env.version().endsWith("dev")
|
|
||||||
? process.env.GITHUB_SHA || "dev"
|
|
||||||
: env.version();
|
|
||||||
return `https://raw.githubusercontent.com/home-assistant/frontend/${ref}`;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Files from NPM Packages that should not be imported
|
// Files from NPM Packages that should not be imported
|
||||||
// eslint-disable-next-line unused-imports/no-unused-vars
|
// eslint-disable-next-line unused-imports/no-unused-vars
|
||||||
@@ -62,26 +53,13 @@ module.exports.definedVars = ({ isProdBuild, latestBuild, defineOverlay }) => ({
|
|||||||
...defineOverlay,
|
...defineOverlay,
|
||||||
});
|
});
|
||||||
|
|
||||||
module.exports.htmlMinifierOptions = {
|
module.exports.terserOptions = (latestBuild) => ({
|
||||||
caseSensitive: true,
|
|
||||||
collapseWhitespace: true,
|
|
||||||
conservativeCollapse: true,
|
|
||||||
decodeEntities: true,
|
|
||||||
removeComments: true,
|
|
||||||
removeRedundantAttributes: true,
|
|
||||||
minifyCSS: {
|
|
||||||
compatibility: "*,-properties.zeroUnits",
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
module.exports.terserOptions = ({ latestBuild, isTestBuild }) => ({
|
|
||||||
safari10: !latestBuild,
|
safari10: !latestBuild,
|
||||||
ecma: latestBuild ? undefined : 5,
|
ecma: latestBuild ? undefined : 5,
|
||||||
format: { comments: false },
|
output: { comments: false },
|
||||||
sourceMap: !isTestBuild,
|
|
||||||
});
|
});
|
||||||
|
|
||||||
module.exports.babelOptions = ({ latestBuild, isProdBuild, isTestBuild }) => ({
|
module.exports.babelOptions = ({ latestBuild }) => ({
|
||||||
babelrc: false,
|
babelrc: false,
|
||||||
compact: false,
|
compact: false,
|
||||||
presets: [
|
presets: [
|
||||||
@@ -89,7 +67,7 @@ module.exports.babelOptions = ({ latestBuild, isProdBuild, isTestBuild }) => ({
|
|||||||
"@babel/preset-env",
|
"@babel/preset-env",
|
||||||
{
|
{
|
||||||
useBuiltIns: "entry",
|
useBuiltIns: "entry",
|
||||||
corejs: { version: "3.30", proposals: true },
|
corejs: "3.15",
|
||||||
bugfixes: true,
|
bugfixes: true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@@ -99,7 +77,7 @@ module.exports.babelOptions = ({ latestBuild, isProdBuild, isTestBuild }) => ({
|
|||||||
[
|
[
|
||||||
path.resolve(
|
path.resolve(
|
||||||
paths.polymer_dir,
|
paths.polymer_dir,
|
||||||
"build-scripts/babel-plugins/inline-constants-plugin.cjs"
|
"build-scripts/babel-plugins/inline-constants-plugin.js"
|
||||||
),
|
),
|
||||||
{
|
{
|
||||||
modules: ["@mdi/js"],
|
modules: ["@mdi/js"],
|
||||||
@@ -115,41 +93,20 @@ module.exports.babelOptions = ({ latestBuild, isProdBuild, isTestBuild }) => ({
|
|||||||
"@babel/plugin-syntax-import-meta",
|
"@babel/plugin-syntax-import-meta",
|
||||||
"@babel/plugin-syntax-dynamic-import",
|
"@babel/plugin-syntax-dynamic-import",
|
||||||
"@babel/plugin-syntax-top-level-await",
|
"@babel/plugin-syntax-top-level-await",
|
||||||
// Support various proposals
|
|
||||||
"@babel/plugin-proposal-optional-chaining",
|
"@babel/plugin-proposal-optional-chaining",
|
||||||
"@babel/plugin-proposal-nullish-coalescing-operator",
|
"@babel/plugin-proposal-nullish-coalescing-operator",
|
||||||
["@babel/plugin-proposal-decorators", { decoratorsBeforeExport: true }],
|
["@babel/plugin-proposal-decorators", { decoratorsBeforeExport: true }],
|
||||||
["@babel/plugin-proposal-private-methods", { loose: true }],
|
["@babel/plugin-proposal-private-methods", { loose: true }],
|
||||||
["@babel/plugin-proposal-private-property-in-object", { loose: true }],
|
["@babel/plugin-proposal-private-property-in-object", { loose: true }],
|
||||||
["@babel/plugin-proposal-class-properties", { loose: true }],
|
["@babel/plugin-proposal-class-properties", { loose: true }],
|
||||||
// Minify template literals for production
|
|
||||||
isProdBuild && [
|
|
||||||
"template-html-minifier",
|
|
||||||
{
|
|
||||||
modules: {
|
|
||||||
lit: [
|
|
||||||
"html",
|
|
||||||
{ name: "svg", encapsulation: "svg" },
|
|
||||||
{ name: "css", encapsulation: "style" },
|
|
||||||
],
|
|
||||||
"@polymer/polymer/lib/utils/html-tag": ["html"],
|
|
||||||
},
|
|
||||||
strictCSS: true,
|
|
||||||
htmlMinifier: module.exports.htmlMinifierOptions,
|
|
||||||
failOnError: true, // we can turn this off in case of false positives
|
|
||||||
},
|
|
||||||
],
|
|
||||||
].filter(Boolean),
|
].filter(Boolean),
|
||||||
exclude: [
|
exclude: [
|
||||||
// \\ for Windows, / for Mac OS and Linux
|
// \\ for Windows, / for Mac OS and Linux
|
||||||
/node_modules[\\/]core-js/,
|
/node_modules[\\/]core-js/,
|
||||||
/node_modules[\\/]webpack[\\/]buildin/,
|
/node_modules[\\/]webpack[\\/]buildin/,
|
||||||
],
|
],
|
||||||
sourceMaps: !isTestBuild,
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const nameSuffix = (latestBuild) => (latestBuild ? "-latest" : "-es5");
|
|
||||||
|
|
||||||
const outputPath = (outputRoot, latestBuild) =>
|
const outputPath = (outputRoot, latestBuild) =>
|
||||||
path.resolve(outputRoot, latestBuild ? "frontend_latest" : "frontend_es5");
|
path.resolve(outputRoot, latestBuild ? "frontend_latest" : "frontend_es5");
|
||||||
|
|
||||||
@@ -172,17 +129,14 @@ BundleConfig {
|
|||||||
latestBuild: boolean,
|
latestBuild: boolean,
|
||||||
// If we're doing a stats build (create nice chunk names)
|
// If we're doing a stats build (create nice chunk names)
|
||||||
isStatsBuild: boolean,
|
isStatsBuild: boolean,
|
||||||
// If it's just a test build in CI, skip time on source map generation
|
|
||||||
isTestBuild: boolean,
|
|
||||||
// Names of entrypoints that should not be hashed
|
// Names of entrypoints that should not be hashed
|
||||||
dontHash: Set<string>
|
dontHash: Set<string>
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
module.exports.config = {
|
module.exports.config = {
|
||||||
app({ isProdBuild, latestBuild, isStatsBuild, isTestBuild, isWDS }) {
|
app({ isProdBuild, latestBuild, isStatsBuild, isWDS }) {
|
||||||
return {
|
return {
|
||||||
name: "app" + nameSuffix(latestBuild),
|
|
||||||
entry: {
|
entry: {
|
||||||
service_worker: "./src/entrypoints/service_worker.ts",
|
service_worker: "./src/entrypoints/service_worker.ts",
|
||||||
app: "./src/entrypoints/app.ts",
|
app: "./src/entrypoints/app.ts",
|
||||||
@@ -196,14 +150,12 @@ module.exports.config = {
|
|||||||
isProdBuild,
|
isProdBuild,
|
||||||
latestBuild,
|
latestBuild,
|
||||||
isStatsBuild,
|
isStatsBuild,
|
||||||
isTestBuild,
|
|
||||||
isWDS,
|
isWDS,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
demo({ isProdBuild, latestBuild, isStatsBuild }) {
|
demo({ isProdBuild, latestBuild, isStatsBuild }) {
|
||||||
return {
|
return {
|
||||||
name: "demo" + nameSuffix(latestBuild),
|
|
||||||
entry: {
|
entry: {
|
||||||
main: path.resolve(paths.demo_dir, "src/entrypoint.ts"),
|
main: path.resolve(paths.demo_dir, "src/entrypoint.ts"),
|
||||||
},
|
},
|
||||||
@@ -233,7 +185,6 @@ module.exports.config = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
name: "cast" + nameSuffix(latestBuild),
|
|
||||||
entry,
|
entry,
|
||||||
outputPath: outputPath(paths.cast_output_root, latestBuild),
|
outputPath: outputPath(paths.cast_output_root, latestBuild),
|
||||||
publicPath: publicPath(latestBuild),
|
publicPath: publicPath(latestBuild),
|
||||||
@@ -245,9 +196,8 @@ module.exports.config = {
|
|||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
hassio({ isProdBuild, latestBuild, isStatsBuild, isTestBuild }) {
|
hassio({ isProdBuild, latestBuild }) {
|
||||||
return {
|
return {
|
||||||
name: "supervisor" + nameSuffix(latestBuild),
|
|
||||||
entry: {
|
entry: {
|
||||||
entrypoint: path.resolve(paths.hassio_dir, "src/entrypoint.ts"),
|
entrypoint: path.resolve(paths.hassio_dir, "src/entrypoint.ts"),
|
||||||
},
|
},
|
||||||
@@ -255,8 +205,6 @@ module.exports.config = {
|
|||||||
publicPath: publicPath(latestBuild, paths.hassio_publicPath),
|
publicPath: publicPath(latestBuild, paths.hassio_publicPath),
|
||||||
isProdBuild,
|
isProdBuild,
|
||||||
latestBuild,
|
latestBuild,
|
||||||
isStatsBuild,
|
|
||||||
isTestBuild,
|
|
||||||
isHassioBuild: true,
|
isHassioBuild: true,
|
||||||
defineOverlay: {
|
defineOverlay: {
|
||||||
__SUPERVISOR__: true,
|
__SUPERVISOR__: true,
|
||||||
@@ -266,7 +214,6 @@ module.exports.config = {
|
|||||||
|
|
||||||
gallery({ isProdBuild, latestBuild }) {
|
gallery({ isProdBuild, latestBuild }) {
|
||||||
return {
|
return {
|
||||||
name: "gallery" + nameSuffix(latestBuild),
|
|
||||||
entry: {
|
entry: {
|
||||||
entrypoint: path.resolve(paths.gallery_dir, "src/entrypoint.js"),
|
entrypoint: path.resolve(paths.gallery_dir, "src/entrypoint.js"),
|
||||||
},
|
},
|
@@ -1,6 +1,6 @@
|
|||||||
const fs = require("fs");
|
const fs = require("fs");
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
const paths = require("./paths.cjs");
|
const paths = require("./paths.js");
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
useRollup() {
|
useRollup() {
|
||||||
@@ -17,7 +17,7 @@ module.exports = {
|
|||||||
isStatsBuild() {
|
isStatsBuild() {
|
||||||
return process.env.STATS === "1";
|
return process.env.STATS === "1";
|
||||||
},
|
},
|
||||||
isTestBuild() {
|
isTest() {
|
||||||
return process.env.IS_TEST === "true";
|
return process.env.IS_TEST === "true";
|
||||||
},
|
},
|
||||||
isNetlify() {
|
isNetlify() {
|
@@ -1,18 +1,19 @@
|
|||||||
// Run HA develop mode
|
// Run HA develop mode
|
||||||
|
|
||||||
const gulp = require("gulp");
|
const gulp = require("gulp");
|
||||||
const env = require("../env.cjs");
|
|
||||||
require("./clean.cjs");
|
const env = require("../env");
|
||||||
require("./translations.cjs");
|
|
||||||
require("./locale-data.cjs");
|
require("./clean.js");
|
||||||
require("./gen-icons-json.cjs");
|
require("./translations.js");
|
||||||
require("./gather-static.cjs");
|
require("./locale-data.js");
|
||||||
require("./compress.cjs");
|
require("./gen-icons-json.js");
|
||||||
require("./webpack.cjs");
|
require("./gather-static.js");
|
||||||
require("./service-worker.cjs");
|
require("./compress.js");
|
||||||
require("./entry-html.cjs");
|
require("./webpack.js");
|
||||||
require("./rollup.cjs");
|
require("./service-worker.js");
|
||||||
require("./wds.cjs");
|
require("./entry-html.js");
|
||||||
|
require("./rollup.js");
|
||||||
|
require("./wds.js");
|
||||||
|
|
||||||
gulp.task(
|
gulp.task(
|
||||||
"develop-app",
|
"develop-app",
|
||||||
@@ -49,7 +50,7 @@ gulp.task(
|
|||||||
"copy-static-app",
|
"copy-static-app",
|
||||||
env.useRollup() ? "rollup-prod-app" : "webpack-prod-app",
|
env.useRollup() ? "rollup-prod-app" : "webpack-prod-app",
|
||||||
// Don't compress running tests
|
// Don't compress running tests
|
||||||
...(env.isTestBuild() ? [] : ["compress-app"]),
|
...(env.isTest() ? [] : ["compress-app"]),
|
||||||
gulp.parallel(
|
gulp.parallel(
|
||||||
"gen-pages-prod",
|
"gen-pages-prod",
|
||||||
"gen-index-app-prod",
|
"gen-index-app-prod",
|
@@ -1,13 +1,14 @@
|
|||||||
const gulp = require("gulp");
|
const gulp = require("gulp");
|
||||||
const env = require("../env.cjs");
|
|
||||||
|
|
||||||
require("./clean.cjs");
|
const env = require("../env");
|
||||||
require("./translations.cjs");
|
|
||||||
require("./gather-static.cjs");
|
require("./clean.js");
|
||||||
require("./webpack.cjs");
|
require("./translations.js");
|
||||||
require("./service-worker.cjs");
|
require("./gather-static.js");
|
||||||
require("./entry-html.cjs");
|
require("./webpack.js");
|
||||||
require("./rollup.cjs");
|
require("./service-worker.js");
|
||||||
|
require("./entry-html.js");
|
||||||
|
require("./rollup.js");
|
||||||
|
|
||||||
gulp.task(
|
gulp.task(
|
||||||
"develop-cast",
|
"develop-cast",
|
@@ -1,7 +1,7 @@
|
|||||||
const del = import("del");
|
const del = import("del");
|
||||||
const gulp = require("gulp");
|
const gulp = require("gulp");
|
||||||
const paths = require("../paths.cjs");
|
const paths = require("../paths");
|
||||||
require("./translations.cjs");
|
require("./translations");
|
||||||
|
|
||||||
gulp.task(
|
gulp.task(
|
||||||
"clean",
|
"clean",
|
@@ -4,7 +4,7 @@ const gulp = require("gulp");
|
|||||||
const zopfli = require("gulp-zopfli-green");
|
const zopfli = require("gulp-zopfli-green");
|
||||||
const merge = require("merge-stream");
|
const merge = require("merge-stream");
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
const paths = require("../paths.cjs");
|
const paths = require("../paths");
|
||||||
|
|
||||||
const zopfliOptions = { threshold: 150 };
|
const zopfliOptions = { threshold: 150 };
|
||||||
|
|
@@ -1,15 +1,16 @@
|
|||||||
// Run demo develop mode
|
// Run demo develop mode
|
||||||
const gulp = require("gulp");
|
const gulp = require("gulp");
|
||||||
const env = require("../env.cjs");
|
|
||||||
|
|
||||||
require("./clean.cjs");
|
const env = require("../env");
|
||||||
require("./translations.cjs");
|
|
||||||
require("./gen-icons-json.cjs");
|
require("./clean.js");
|
||||||
require("./gather-static.cjs");
|
require("./translations.js");
|
||||||
require("./webpack.cjs");
|
require("./gen-icons-json.js");
|
||||||
require("./service-worker.cjs");
|
require("./gather-static.js");
|
||||||
require("./entry-html.cjs");
|
require("./webpack.js");
|
||||||
require("./rollup.cjs");
|
require("./service-worker.js");
|
||||||
|
require("./entry-html.js");
|
||||||
|
require("./rollup.js");
|
||||||
|
|
||||||
gulp.task(
|
gulp.task(
|
||||||
"develop-demo",
|
"develop-demo",
|
@@ -3,10 +3,9 @@ const gulp = require("gulp");
|
|||||||
const fs = require("fs-extra");
|
const fs = require("fs-extra");
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
const template = require("lodash.template");
|
const template = require("lodash.template");
|
||||||
const { minify } = require("html-minifier-terser");
|
const minify = require("html-minifier").minify;
|
||||||
const paths = require("../paths.cjs");
|
const paths = require("../paths.js");
|
||||||
const env = require("../env.cjs");
|
const env = require("../env.js");
|
||||||
const { htmlMinifierOptions, terserOptions } = require("../bundle.cjs");
|
|
||||||
|
|
||||||
const templatePath = (tpl) =>
|
const templatePath = (tpl) =>
|
||||||
path.resolve(paths.polymer_dir, "src/html/", `${tpl}.html.template`);
|
path.resolve(paths.polymer_dir, "src/html/", `${tpl}.html.template`);
|
||||||
@@ -40,12 +39,10 @@ const renderGalleryTemplate = (pth, data = {}) =>
|
|||||||
|
|
||||||
const minifyHtml = (content) =>
|
const minifyHtml = (content) =>
|
||||||
minify(content, {
|
minify(content, {
|
||||||
...htmlMinifierOptions,
|
collapseWhitespace: true,
|
||||||
conservativeCollapse: false,
|
minifyJS: true,
|
||||||
minifyJS: terserOptions({
|
minifyCSS: true,
|
||||||
latestBuild: false, // Shared scripts should be ES5
|
removeComments: true,
|
||||||
isTestBuild: true, // Don't need source maps
|
|
||||||
}),
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const PAGES = ["onboarding", "authorize"];
|
const PAGES = ["onboarding", "authorize"];
|
||||||
@@ -66,7 +63,7 @@ gulp.task("gen-pages-dev", (done) => {
|
|||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task("gen-pages-prod", async () => {
|
gulp.task("gen-pages-prod", (done) => {
|
||||||
const latestManifest = require(path.resolve(
|
const latestManifest = require(path.resolve(
|
||||||
paths.app_output_latest,
|
paths.app_output_latest,
|
||||||
"manifest.json"
|
"manifest.json"
|
||||||
@@ -76,23 +73,19 @@ gulp.task("gen-pages-prod", async () => {
|
|||||||
"manifest.json"
|
"manifest.json"
|
||||||
));
|
));
|
||||||
|
|
||||||
const minifiedHTML = [];
|
|
||||||
for (const page of PAGES) {
|
for (const page of PAGES) {
|
||||||
const content = renderTemplate(page, {
|
const content = renderTemplate(page, {
|
||||||
latestPageJS: latestManifest[`${page}.js`],
|
latestPageJS: latestManifest[`${page}.js`],
|
||||||
|
|
||||||
es5PageJS: es5Manifest[`${page}.js`],
|
es5PageJS: es5Manifest[`${page}.js`],
|
||||||
});
|
});
|
||||||
|
|
||||||
minifiedHTML.push(
|
fs.outputFileSync(
|
||||||
minifyHtml(content).then((minified) =>
|
path.resolve(paths.app_output_root, `${page}.html`),
|
||||||
fs.outputFileSync(
|
minifyHtml(content)
|
||||||
path.resolve(paths.app_output_root, `${page}.html`),
|
|
||||||
minified
|
|
||||||
)
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
await Promise.all(minifiedHTML);
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task("gen-index-app-dev", (done) => {
|
gulp.task("gen-index-app-dev", (done) => {
|
||||||
@@ -125,7 +118,7 @@ gulp.task("gen-index-app-dev", (done) => {
|
|||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task("gen-index-app-prod", async () => {
|
gulp.task("gen-index-app-prod", (done) => {
|
||||||
const latestManifest = require(path.resolve(
|
const latestManifest = require(path.resolve(
|
||||||
paths.app_output_latest,
|
paths.app_output_latest,
|
||||||
"manifest.json"
|
"manifest.json"
|
||||||
@@ -143,15 +136,13 @@ gulp.task("gen-index-app-prod", async () => {
|
|||||||
es5CoreJS: es5Manifest["core.js"],
|
es5CoreJS: es5Manifest["core.js"],
|
||||||
es5CustomPanelJS: es5Manifest["custom-panel.js"],
|
es5CustomPanelJS: es5Manifest["custom-panel.js"],
|
||||||
});
|
});
|
||||||
const minified = (await minifyHtml(content)).replace(
|
const minified = minifyHtml(content).replace(/#THEMEC/g, "{{ theme_color }}");
|
||||||
/#THEMEC/g,
|
|
||||||
"{{ theme_color }}"
|
|
||||||
);
|
|
||||||
|
|
||||||
fs.outputFileSync(
|
fs.outputFileSync(
|
||||||
path.resolve(paths.app_output_root, "index.html"),
|
path.resolve(paths.app_output_root, "index.html"),
|
||||||
minified
|
minified
|
||||||
);
|
);
|
||||||
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task("gen-index-cast-dev", (done) => {
|
gulp.task("gen-index-cast-dev", (done) => {
|
||||||
@@ -253,7 +244,7 @@ gulp.task("gen-index-demo-dev", (done) => {
|
|||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task("gen-index-demo-prod", async () => {
|
gulp.task("gen-index-demo-prod", (done) => {
|
||||||
const latestManifest = require(path.resolve(
|
const latestManifest = require(path.resolve(
|
||||||
paths.demo_output_latest,
|
paths.demo_output_latest,
|
||||||
"manifest.json"
|
"manifest.json"
|
||||||
@@ -267,12 +258,13 @@ gulp.task("gen-index-demo-prod", async () => {
|
|||||||
|
|
||||||
es5DemoJS: es5Manifest["main.js"],
|
es5DemoJS: es5Manifest["main.js"],
|
||||||
});
|
});
|
||||||
const minified = await minifyHtml(content);
|
const minified = minifyHtml(content);
|
||||||
|
|
||||||
fs.outputFileSync(
|
fs.outputFileSync(
|
||||||
path.resolve(paths.demo_output_root, "index.html"),
|
path.resolve(paths.demo_output_root, "index.html"),
|
||||||
minified
|
minified
|
||||||
);
|
);
|
||||||
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task("gen-index-gallery-dev", (done) => {
|
gulp.task("gen-index-gallery-dev", (done) => {
|
||||||
@@ -287,7 +279,7 @@ gulp.task("gen-index-gallery-dev", (done) => {
|
|||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task("gen-index-gallery-prod", async () => {
|
gulp.task("gen-index-gallery-prod", (done) => {
|
||||||
const latestManifest = require(path.resolve(
|
const latestManifest = require(path.resolve(
|
||||||
paths.gallery_output_latest,
|
paths.gallery_output_latest,
|
||||||
"manifest.json"
|
"manifest.json"
|
||||||
@@ -295,12 +287,13 @@ gulp.task("gen-index-gallery-prod", async () => {
|
|||||||
const content = renderGalleryTemplate("index", {
|
const content = renderGalleryTemplate("index", {
|
||||||
latestGalleryJS: latestManifest["entrypoint.js"],
|
latestGalleryJS: latestManifest["entrypoint.js"],
|
||||||
});
|
});
|
||||||
const minified = await minifyHtml(content);
|
const minified = minifyHtml(content);
|
||||||
|
|
||||||
fs.outputFileSync(
|
fs.outputFileSync(
|
||||||
path.resolve(paths.gallery_output_root, "index.html"),
|
path.resolve(paths.gallery_output_root, "index.html"),
|
||||||
minified
|
minified
|
||||||
);
|
);
|
||||||
|
done();
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task("gen-index-hassio-dev", async () => {
|
gulp.task("gen-index-hassio-dev", async () => {
|
@@ -8,7 +8,6 @@ const gulp = require("gulp");
|
|||||||
const jszip = require("jszip");
|
const jszip = require("jszip");
|
||||||
const tar = require("tar");
|
const tar = require("tar");
|
||||||
const { Octokit } = require("@octokit/rest");
|
const { Octokit } = require("@octokit/rest");
|
||||||
const { retry } = require("@octokit/plugin-retry");
|
|
||||||
const { createOAuthDeviceAuth } = require("@octokit/auth-oauth-device");
|
const { createOAuthDeviceAuth } = require("@octokit/auth-oauth-device");
|
||||||
|
|
||||||
const MAX_AGE = 24; // hours
|
const MAX_AGE = 24; // hours
|
||||||
@@ -96,7 +95,7 @@ gulp.task("fetch-nightly-translations", async function () {
|
|||||||
|
|
||||||
// Authenticate with token and request workflow runs from GitHub
|
// Authenticate with token and request workflow runs from GitHub
|
||||||
console.log("Fetching new translations...");
|
console.log("Fetching new translations...");
|
||||||
const octokit = new (Octokit.plugin(retry))({
|
const octokit = new Octokit({
|
||||||
userAgent: "Fetch Nightly Translations",
|
userAgent: "Fetch Nightly Translations",
|
||||||
auth: tokenAuth.token,
|
auth: tokenAuth.token,
|
||||||
});
|
});
|
@@ -3,24 +3,24 @@ const gulp = require("gulp");
|
|||||||
const fs = require("fs");
|
const fs = require("fs");
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
const { marked } = require("marked");
|
const { marked } = require("marked");
|
||||||
const { glob } = require("glob");
|
const glob = require("glob");
|
||||||
const yaml = require("js-yaml");
|
const yaml = require("js-yaml");
|
||||||
|
|
||||||
const env = require("../env.cjs");
|
const env = require("../env");
|
||||||
const paths = require("../paths.cjs");
|
const paths = require("../paths");
|
||||||
|
|
||||||
require("./clean.cjs");
|
require("./clean.js");
|
||||||
require("./translations.cjs");
|
require("./translations.js");
|
||||||
require("./gen-icons-json.cjs");
|
require("./gen-icons-json.js");
|
||||||
require("./gather-static.cjs");
|
require("./gather-static.js");
|
||||||
require("./webpack.cjs");
|
require("./webpack.js");
|
||||||
require("./service-worker.cjs");
|
require("./service-worker.js");
|
||||||
require("./entry-html.cjs");
|
require("./entry-html.js");
|
||||||
require("./rollup.cjs");
|
require("./rollup.js");
|
||||||
|
|
||||||
gulp.task("gather-gallery-pages", async function gatherPages() {
|
gulp.task("gather-gallery-pages", async function gatherPages() {
|
||||||
const pageDir = path.resolve(paths.gallery_dir, "src/pages");
|
const pageDir = path.resolve(paths.gallery_dir, "src/pages");
|
||||||
const files = await glob(path.resolve(pageDir, "**/*"));
|
const files = glob.sync(path.resolve(pageDir, "**/*"));
|
||||||
|
|
||||||
const galleryBuild = path.resolve(paths.gallery_dir, "build");
|
const galleryBuild = path.resolve(paths.gallery_dir, "build");
|
||||||
fs.mkdirSync(galleryBuild, { recursive: true });
|
fs.mkdirSync(galleryBuild, { recursive: true });
|
||||||
@@ -89,7 +89,9 @@ gulp.task("gather-gallery-pages", async function gatherPages() {
|
|||||||
|
|
||||||
// Generate sidebar
|
// Generate sidebar
|
||||||
const sidebarPath = path.resolve(paths.gallery_dir, "sidebar.js");
|
const sidebarPath = path.resolve(paths.gallery_dir, "sidebar.js");
|
||||||
const sidebar = (await import(sidebarPath)).default;
|
// To make watch work during development
|
||||||
|
delete require.cache[sidebarPath];
|
||||||
|
const sidebar = require(sidebarPath);
|
||||||
|
|
||||||
const pagesToProcess = {};
|
const pagesToProcess = {};
|
||||||
for (const key of processed) {
|
for (const key of processed) {
|
@@ -3,7 +3,7 @@
|
|||||||
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 paths = require("../paths.cjs");
|
const paths = require("../paths");
|
||||||
|
|
||||||
const npmPath = (...parts) =>
|
const npmPath = (...parts) =>
|
||||||
path.resolve(paths.polymer_dir, "node_modules", ...parts);
|
path.resolve(paths.polymer_dir, "node_modules", ...parts);
|
@@ -134,11 +134,11 @@ gulp.task("gen-icons-json", (done) => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
const file = fs.readFileSync(PACKAGE_PATH, { encoding });
|
const file = fs.readFileSync(PACKAGE_PATH, { encoding });
|
||||||
const packageMeta = JSON.parse(file);
|
const package = JSON.parse(file);
|
||||||
|
|
||||||
fs.writeFileSync(
|
fs.writeFileSync(
|
||||||
path.resolve(OUTPUT_DIR, "iconMetadata.json"),
|
path.resolve(OUTPUT_DIR, "iconMetadata.json"),
|
||||||
JSON.stringify({ version: packageMeta.version, parts })
|
JSON.stringify({ version: package.version, parts })
|
||||||
);
|
);
|
||||||
|
|
||||||
fs.writeFileSync(
|
fs.writeFileSync(
|
@@ -1,13 +1,15 @@
|
|||||||
const gulp = require("gulp");
|
const gulp = require("gulp");
|
||||||
const env = require("../env.cjs");
|
|
||||||
require("./clean.cjs");
|
const env = require("../env");
|
||||||
require("./compress.cjs");
|
|
||||||
require("./entry-html.cjs");
|
require("./clean.js");
|
||||||
require("./gather-static.cjs");
|
require("./gen-icons-json.js");
|
||||||
require("./gen-icons-json.cjs");
|
require("./webpack.js");
|
||||||
require("./rollup.cjs");
|
require("./compress.js");
|
||||||
require("./translations.cjs");
|
require("./rollup.js");
|
||||||
require("./webpack.cjs");
|
require("./gather-static.js");
|
||||||
|
require("./translations.js");
|
||||||
|
require("./gen-icons-json.js");
|
||||||
|
|
||||||
gulp.task(
|
gulp.task(
|
||||||
"develop-hassio",
|
"develop-hassio",
|
||||||
@@ -41,6 +43,6 @@ gulp.task(
|
|||||||
env.useRollup() ? "rollup-prod-hassio" : "webpack-prod-hassio",
|
env.useRollup() ? "rollup-prod-hassio" : "webpack-prod-hassio",
|
||||||
"gen-index-hassio-prod",
|
"gen-index-hassio-prod",
|
||||||
...// Don't compress running tests
|
...// Don't compress running tests
|
||||||
(env.isTestBuild() ? [] : ["compress-hassio"])
|
(env.isTest() ? [] : ["compress-hassio"])
|
||||||
)
|
)
|
||||||
);
|
);
|
@@ -2,7 +2,7 @@ const del = import("del");
|
|||||||
const path = require("path");
|
const path = require("path");
|
||||||
const gulp = require("gulp");
|
const gulp = require("gulp");
|
||||||
const fs = require("fs");
|
const fs = require("fs");
|
||||||
const paths = require("../paths.cjs");
|
const paths = require("../paths");
|
||||||
|
|
||||||
const outDir = "build/locale-data";
|
const outDir = "build/locale-data";
|
||||||
|
|
@@ -6,8 +6,8 @@ const handler = require("serve-handler");
|
|||||||
const http = require("http");
|
const http = require("http");
|
||||||
const log = require("fancy-log");
|
const log = require("fancy-log");
|
||||||
const open = require("open");
|
const open = require("open");
|
||||||
const rollupConfig = require("../rollup.cjs");
|
const rollupConfig = require("../rollup");
|
||||||
const paths = require("../paths.cjs");
|
const paths = require("../paths");
|
||||||
|
|
||||||
const bothBuilds = (createConfigFunc, params) =>
|
const bothBuilds = (createConfigFunc, params) =>
|
||||||
gulp.series(
|
gulp.series(
|
||||||
@@ -46,7 +46,7 @@ function createServer(serveOptions) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function watchRollup(createConfig, extraWatchSrc = [], serveOptions = null) {
|
function watchRollup(createConfig, extraWatchSrc = [], serveOptions) {
|
||||||
const { inputOptions, outputOptions } = createConfig({
|
const { inputOptions, outputOptions } = createConfig({
|
||||||
isProdBuild: false,
|
isProdBuild: false,
|
||||||
latestBuild: true,
|
latestBuild: true,
|
@@ -5,7 +5,7 @@ const path = require("path");
|
|||||||
const fs = require("fs-extra");
|
const fs = require("fs-extra");
|
||||||
const workboxBuild = require("workbox-build");
|
const workboxBuild = require("workbox-build");
|
||||||
const sourceMapUrl = require("source-map-url");
|
const sourceMapUrl = require("source-map-url");
|
||||||
const paths = require("../paths.cjs");
|
const paths = require("../paths.js");
|
||||||
|
|
||||||
const swDest = path.resolve(paths.app_output_root, "service_worker.js");
|
const swDest = path.resolve(paths.app_output_root, "service_worker.js");
|
||||||
|
|
@@ -9,11 +9,11 @@ const flatmap = require("gulp-flatmap");
|
|||||||
const merge = require("gulp-merge-json");
|
const merge = require("gulp-merge-json");
|
||||||
const rename = require("gulp-rename");
|
const rename = require("gulp-rename");
|
||||||
const transform = require("gulp-json-transform");
|
const transform = require("gulp-json-transform");
|
||||||
const { mapFiles } = require("../util.cjs");
|
const { mapFiles } = require("../util");
|
||||||
const env = require("../env.cjs");
|
const env = require("../env");
|
||||||
const paths = require("../paths.cjs");
|
const paths = require("../paths");
|
||||||
|
|
||||||
require("./fetch-nightly-translations.cjs");
|
require("./fetch-nightly-translations");
|
||||||
|
|
||||||
const inFrontendDir = "translations/frontend";
|
const inFrontendDir = "translations/frontend";
|
||||||
const inBackendDir = "translations/backend";
|
const inBackendDir = "translations/backend";
|
@@ -5,15 +5,14 @@ const webpack = require("webpack");
|
|||||||
const WebpackDevServer = require("webpack-dev-server");
|
const WebpackDevServer = require("webpack-dev-server");
|
||||||
const log = require("fancy-log");
|
const log = require("fancy-log");
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
const env = require("../env.cjs");
|
const paths = require("../paths");
|
||||||
const paths = require("../paths.cjs");
|
|
||||||
const {
|
const {
|
||||||
createAppConfig,
|
createAppConfig,
|
||||||
createDemoConfig,
|
createDemoConfig,
|
||||||
createCastConfig,
|
createCastConfig,
|
||||||
createHassioConfig,
|
createHassioConfig,
|
||||||
createGalleryConfig,
|
createGalleryConfig,
|
||||||
} = require("../webpack.cjs");
|
} = require("../webpack");
|
||||||
|
|
||||||
const bothBuilds = (createConfigFunc, params) => [
|
const bothBuilds = (createConfigFunc, params) => [
|
||||||
createConfigFunc({ ...params, latestBuild: true }),
|
createConfigFunc({ ...params, latestBuild: true }),
|
||||||
@@ -105,8 +104,6 @@ gulp.task("webpack-prod-app", () =>
|
|||||||
prodBuild(
|
prodBuild(
|
||||||
bothBuilds(createAppConfig, {
|
bothBuilds(createAppConfig, {
|
||||||
isProdBuild: true,
|
isProdBuild: true,
|
||||||
isStatsBuild: env.isStatsBuild(),
|
|
||||||
isTestBuild: env.isTestBuild(),
|
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@@ -164,8 +161,6 @@ gulp.task("webpack-prod-hassio", () =>
|
|||||||
prodBuild(
|
prodBuild(
|
||||||
bothBuilds(createHassioConfig, {
|
bothBuilds(createHassioConfig, {
|
||||||
isProdBuild: true,
|
isProdBuild: true,
|
||||||
isStatsBuild: env.isStatsBuild(),
|
|
||||||
isTestBuild: env.isTestBuild(),
|
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
);
|
);
|
@@ -1 +1,30 @@
|
|||||||
[]
|
[
|
||||||
|
{
|
||||||
|
"path": "M20,20H7A2,2 0 0,1 5,18V8.94L2.23,5.64C2.09,5.47 2,5.24 2,5A1,1 0 0,1 3,4H20A2,2 0 0,1 22,6V18A2,2 0 0,1 20,20M8.5,7A0.5,0.5 0 0,0 8,7.5V8.5A0.5,0.5 0 0,0 8.5,9H18.5A0.5,0.5 0 0,0 19,8.5V7.5A0.5,0.5 0 0,0 18.5,7H8.5M8.5,11A0.5,0.5 0 0,0 8,11.5V12.5A0.5,0.5 0 0,0 8.5,13H18.5A0.5,0.5 0 0,0 19,12.5V11.5A0.5,0.5 0 0,0 18.5,11H8.5M8.5,15A0.5,0.5 0 0,0 8,15.5V16.5A0.5,0.5 0 0,0 8.5,17H13.5A0.5,0.5 0 0,0 14,16.5V15.5A0.5,0.5 0 0,0 13.5,15H8.5Z",
|
||||||
|
"name": "android-messages"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "M4,6H2V20A2,2 0 0,0 4,22H18V20H4V6M20,2H8A2,2 0 0,0 6,4V16A2,2 0 0,0 8,18H20A2,2 0 0,0 22,16V4A2,2 0 0,0 20,2M20,12L17.5,10.5L15,12V4H20V12Z",
|
||||||
|
"name": "book-variant-multiple"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "M21,14H3V4H21M21,2H3C1.89,2 1,2.89 1,4V16A2,2 0 0,0 3,18H10L8,21V22H16V21L14,18H21A2,2 0 0,0 23,16V4C23,2.89 22.1,2 21,2Z",
|
||||||
|
"name": "desktop-mac"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "M21,14V4H3V14H21M21,2A2,2 0 0,1 23,4V16A2,2 0 0,1 21,18H14L16,21V22H8V21L10,18H3C1.89,18 1,17.1 1,16V4C1,2.89 1.89,2 3,2H21M4,5H15V10H4V5M16,5H20V7H16V5M20,8V13H16V8H20M4,11H9V13H4V11M10,11H15V13H10V11Z",
|
||||||
|
"name": "desktop-mac-dashboard"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "M22,24L16.75,19L17.38,21H4.5A2.5,2.5 0 0,1 2,18.5V3.5A2.5,2.5 0 0,1 4.5,1H19.5A2.5,2.5 0 0,1 22,3.5V24M12,6.8C9.32,6.8 7.44,7.95 7.44,7.95C8.47,7.03 10.27,6.5 10.27,6.5L10.1,6.33C8.41,6.36 6.88,7.53 6.88,7.53C5.16,11.12 5.27,14.22 5.27,14.22C6.67,16.03 8.75,15.9 8.75,15.9L9.46,15C8.21,14.73 7.42,13.62 7.42,13.62C7.42,13.62 9.3,14.9 12,14.9C14.7,14.9 16.58,13.62 16.58,13.62C16.58,13.62 15.79,14.73 14.54,15L15.25,15.9C15.25,15.9 17.33,16.03 18.73,14.22C18.73,14.22 18.84,11.12 17.12,7.53C17.12,7.53 15.59,6.36 13.9,6.33L13.73,6.5C13.73,6.5 15.53,7.03 16.56,7.95C16.56,7.95 14.68,6.8 12,6.8M9.93,10.59C10.58,10.59 11.11,11.16 11.1,11.86C11.1,12.55 10.58,13.13 9.93,13.13C9.29,13.13 8.77,12.55 8.77,11.86C8.77,11.16 9.28,10.59 9.93,10.59M14.1,10.59C14.75,10.59 15.27,11.16 15.27,11.86C15.27,12.55 14.75,13.13 14.1,13.13C13.46,13.13 12.94,12.55 12.94,11.86C12.94,11.16 13.45,10.59 14.1,10.59Z",
|
||||||
|
"name": "discord"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "M8.06,7.78C7.5,7.78 7.17,7.73 7.08,7.64L6.66,13.73C7.19,14.05 7.88,14.3 8.72,14.5C9.56,14.71 10.78,14.77 12.38,14.67C13.97,14.58 15.63,14.23 17.34,13.64L16.55,4.22C15.67,5.09 14.38,5.91 12.66,6.66C11.13,7.31 9.81,7.69 8.72,7.78H8.06M7.97,5.34C7.28,5.94 7,6.34 7.13,6.56C7.22,6.78 7.7,6.84 8.58,6.75C9.67,6.66 10.91,6.31 12.28,5.72C13.22,5.31 14.03,4.88 14.72,4.41C15.41,3.94 15.88,3.55 16.13,3.23C16.38,2.92 16.47,2.7 16.41,2.58C16.34,2.42 16.03,2.34 15.47,2.34C14.34,2.34 12.94,2.7 11.25,3.42C9.81,4.05 8.72,4.69 7.97,5.34M17.34,2.2C17.41,2.33 17.44,2.47 17.44,2.63L18.61,17C18.61,18.73 18,20.09 16.83,21.07C15.64,22.05 14.03,22.55 12,22.55C10,22.55 8.4,22.04 7.2,21C6,20 5.39,18.64 5.39,16.92L6.09,6.47C6.09,6.22 6.2,5.94 6.42,5.63C6.64,5.31 6.84,5.06 7.03,4.88L7.36,4.59C8.33,3.78 9.5,3.08 10.88,2.5C11.81,2.08 12.73,1.77 13.62,1.57C14.5,1.37 15.3,1.3 16,1.38C16.71,1.46 17.16,1.73 17.34,2.2Z",
|
||||||
|
"name": "google-home"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "M19.25,19H4.75V3H19.25M14,22H10V21H14M18,0H6A3,3 0 0,0 3,3V21A3,3 0 0,0 6,24H18A3,3 0 0,0 21,21V3A3,3 0 0,0 18,0Z",
|
||||||
|
"name": "tablet-android"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
@@ -103,7 +103,7 @@ module.exports = function (opts = {}) {
|
|||||||
}
|
}
|
||||||
delete optionsObject.type;
|
delete optionsObject.type;
|
||||||
|
|
||||||
if (!/^.*\//.test(workerFile)) {
|
if (!new RegExp("^.*/").test(workerFile)) {
|
||||||
this.warn(
|
this.warn(
|
||||||
`Paths passed to the Worker constructor must be relative or absolute, i.e. start with /, ./ or ../ (just like dynamic import!). Ignoring "${workerFile}".`
|
`Paths passed to the Worker constructor must be relative or absolute, i.e. start with /, ./ or ../ (just like dynamic import!). Ignoring "${workerFile}".`
|
||||||
);
|
);
|
@@ -3,18 +3,18 @@ const path = require("path");
|
|||||||
const commonjs = require("@rollup/plugin-commonjs");
|
const commonjs = require("@rollup/plugin-commonjs");
|
||||||
const resolve = require("@rollup/plugin-node-resolve");
|
const resolve = require("@rollup/plugin-node-resolve");
|
||||||
const json = require("@rollup/plugin-json");
|
const json = require("@rollup/plugin-json");
|
||||||
const { babel } = require("@rollup/plugin-babel");
|
const babel = require("@rollup/plugin-babel").babel;
|
||||||
const replace = require("@rollup/plugin-replace");
|
const replace = require("@rollup/plugin-replace");
|
||||||
const visualizer = require("rollup-plugin-visualizer");
|
const visualizer = require("rollup-plugin-visualizer");
|
||||||
const { string } = require("rollup-plugin-string");
|
const { string } = require("rollup-plugin-string");
|
||||||
const { terser } = require("rollup-plugin-terser");
|
const { terser } = require("rollup-plugin-terser");
|
||||||
const manifest = require("./rollup-plugins/manifest-plugin.cjs");
|
const manifest = require("./rollup-plugins/manifest-plugin");
|
||||||
const worker = require("./rollup-plugins/worker-plugin.cjs");
|
const worker = require("./rollup-plugins/worker-plugin");
|
||||||
const dontHashPlugin = require("./rollup-plugins/dont-hash-plugin.cjs");
|
const dontHashPlugin = require("./rollup-plugins/dont-hash-plugin");
|
||||||
const ignore = require("./rollup-plugins/ignore-plugin.cjs");
|
const ignore = require("./rollup-plugins/ignore-plugin");
|
||||||
|
|
||||||
const bundle = require("./bundle.cjs");
|
const bundle = require("./bundle");
|
||||||
const paths = require("./paths.cjs");
|
const paths = require("./paths");
|
||||||
|
|
||||||
const extensions = [".js", ".ts"];
|
const extensions = [".js", ".ts"];
|
||||||
|
|
||||||
@@ -39,18 +39,11 @@ const createRollupConfig = ({
|
|||||||
inputOptions: {
|
inputOptions: {
|
||||||
input: entry,
|
input: entry,
|
||||||
// Some entry points contain no JavaScript. This setting silences a warning about that.
|
// Some entry points contain no JavaScript. This setting silences a warning about that.
|
||||||
// https://rollupjs.org/configuration-options/#preserveentrysignatures
|
// https://rollupjs.org/guide/en/#preserveentrysignatures
|
||||||
preserveEntrySignatures: false,
|
preserveEntrySignatures: false,
|
||||||
plugins: [
|
plugins: [
|
||||||
ignore({
|
ignore({
|
||||||
files: bundle
|
files: bundle.emptyPackages({ latestBuild }),
|
||||||
.emptyPackages({ latestBuild })
|
|
||||||
// TEMP HACK: Makes Rollup build work again
|
|
||||||
.concat(
|
|
||||||
require.resolve(
|
|
||||||
"@webcomponents/scoped-custom-element-registry/scoped-custom-element-registry.min"
|
|
||||||
)
|
|
||||||
),
|
|
||||||
}),
|
}),
|
||||||
resolve({
|
resolve({
|
||||||
extensions,
|
extensions,
|
||||||
@@ -61,7 +54,7 @@ const createRollupConfig = ({
|
|||||||
commonjs(),
|
commonjs(),
|
||||||
json(),
|
json(),
|
||||||
babel({
|
babel({
|
||||||
...bundle.babelOptions({ latestBuild, isProdBuild }),
|
...bundle.babelOptions({ latestBuild }),
|
||||||
extensions,
|
extensions,
|
||||||
babelHelpers: isWDS ? "inline" : "bundled",
|
babelHelpers: isWDS ? "inline" : "bundled",
|
||||||
}),
|
}),
|
||||||
@@ -76,7 +69,7 @@ const createRollupConfig = ({
|
|||||||
}),
|
}),
|
||||||
!isWDS && worker(),
|
!isWDS && worker(),
|
||||||
!isWDS && dontHashPlugin({ dontHash }),
|
!isWDS && dontHashPlugin({ dontHash }),
|
||||||
!isWDS && isProdBuild && terser(bundle.terserOptions({ latestBuild })),
|
!isWDS && isProdBuild && terser(bundle.terserOptions(latestBuild)),
|
||||||
!isWDS &&
|
!isWDS &&
|
||||||
isStatsBuild &&
|
isStatsBuild &&
|
||||||
visualizer({
|
visualizer({
|
||||||
@@ -90,20 +83,20 @@ const createRollupConfig = ({
|
|||||||
* @type { import("rollup").OutputOptions }
|
* @type { import("rollup").OutputOptions }
|
||||||
*/
|
*/
|
||||||
outputOptions: {
|
outputOptions: {
|
||||||
// https://rollupjs.org/configuration-options/#output-dir
|
// https://rollupjs.org/guide/en/#outputdir
|
||||||
dir: outputPath,
|
dir: outputPath,
|
||||||
// https://rollupjs.org/configuration-options/#output-format
|
// https://rollupjs.org/guide/en/#outputformat
|
||||||
format: latestBuild ? "es" : "systemjs",
|
format: latestBuild ? "es" : "systemjs",
|
||||||
// https://rollupjs.org/configuration-options/#output-externallivebindings
|
// https://rollupjs.org/guide/en/#outputexternallivebindings
|
||||||
externalLiveBindings: false,
|
externalLiveBindings: false,
|
||||||
// https://rollupjs.org/configuration-options/#output-entryfilenames
|
// https://rollupjs.org/guide/en/#outputentryfilenames
|
||||||
// https://rollupjs.org/configuration-options/#output-chunkfilenames
|
// https://rollupjs.org/guide/en/#outputchunkfilenames
|
||||||
// https://rollupjs.org/configuration-options/#output-assetfilenames
|
// https://rollupjs.org/guide/en/#outputassetfilenames
|
||||||
entryFileNames:
|
entryFileNames:
|
||||||
isProdBuild && !isStatsBuild ? "[name]-[hash].js" : "[name].js",
|
isProdBuild && !isStatsBuild ? "[name]-[hash].js" : "[name].js",
|
||||||
chunkFileNames: isProdBuild && !isStatsBuild ? "c.[hash].js" : "[name].js",
|
chunkFileNames: isProdBuild && !isStatsBuild ? "c.[hash].js" : "[name].js",
|
||||||
assetFileNames: isProdBuild && !isStatsBuild ? "a.[hash].js" : "[name].js",
|
assetFileNames: isProdBuild && !isStatsBuild ? "a.[hash].js" : "[name].js",
|
||||||
// https://rollupjs.org/configuration-options/#output-sourcemap
|
// https://rollupjs.org/guide/en/#outputsourcemap
|
||||||
sourcemap: isProdBuild ? true : "inline",
|
sourcemap: isProdBuild ? true : "inline",
|
||||||
},
|
},
|
||||||
});
|
});
|
@@ -4,8 +4,8 @@ const TerserPlugin = require("terser-webpack-plugin");
|
|||||||
const { WebpackManifestPlugin } = require("webpack-manifest-plugin");
|
const { WebpackManifestPlugin } = require("webpack-manifest-plugin");
|
||||||
const log = require("fancy-log");
|
const log = require("fancy-log");
|
||||||
const WebpackBar = require("webpackbar");
|
const WebpackBar = require("webpackbar");
|
||||||
const paths = require("./paths.cjs");
|
const paths = require("./paths.js");
|
||||||
const bundle = require("./bundle.cjs");
|
const bundle = require("./bundle.js");
|
||||||
|
|
||||||
class LogStartCompilePlugin {
|
class LogStartCompilePlugin {
|
||||||
ignoredFirst = false;
|
ignoredFirst = false;
|
||||||
@@ -22,7 +22,6 @@ class LogStartCompilePlugin {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const createWebpackConfig = ({
|
const createWebpackConfig = ({
|
||||||
name,
|
|
||||||
entry,
|
entry,
|
||||||
outputPath,
|
outputPath,
|
||||||
publicPath,
|
publicPath,
|
||||||
@@ -30,7 +29,6 @@ const createWebpackConfig = ({
|
|||||||
isProdBuild,
|
isProdBuild,
|
||||||
latestBuild,
|
latestBuild,
|
||||||
isStatsBuild,
|
isStatsBuild,
|
||||||
isTestBuild,
|
|
||||||
isHassioBuild,
|
isHassioBuild,
|
||||||
dontHash,
|
dontHash,
|
||||||
}) => {
|
}) => {
|
||||||
@@ -39,16 +37,10 @@ const createWebpackConfig = ({
|
|||||||
}
|
}
|
||||||
const ignorePackages = bundle.ignorePackages({ latestBuild });
|
const ignorePackages = bundle.ignorePackages({ latestBuild });
|
||||||
return {
|
return {
|
||||||
name,
|
|
||||||
mode: isProdBuild ? "production" : "development",
|
mode: isProdBuild ? "production" : "development",
|
||||||
target: ["web", latestBuild ? "es2017" : "es5"],
|
target: ["web", latestBuild ? "es2017" : "es5"],
|
||||||
// For tests/CI, source maps are skipped to gain build speed
|
devtool: isProdBuild
|
||||||
// For production, generate source maps for accurate stack traces without source code
|
? "cheap-module-source-map"
|
||||||
// For development, generate "cheap" versions that can map to original line numbers
|
|
||||||
devtool: isTestBuild
|
|
||||||
? false
|
|
||||||
: isProdBuild
|
|
||||||
? "nosources-source-map"
|
|
||||||
: "eval-cheap-module-source-map",
|
: "eval-cheap-module-source-map",
|
||||||
entry,
|
entry,
|
||||||
node: false,
|
node: false,
|
||||||
@@ -59,14 +51,11 @@ const createWebpackConfig = ({
|
|||||||
use: {
|
use: {
|
||||||
loader: "babel-loader",
|
loader: "babel-loader",
|
||||||
options: {
|
options: {
|
||||||
...bundle.babelOptions({ latestBuild, isProdBuild, isTestBuild }),
|
...bundle.babelOptions({ latestBuild }),
|
||||||
cacheDirectory: !isProdBuild,
|
cacheDirectory: !isProdBuild,
|
||||||
cacheCompression: false,
|
cacheCompression: false,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
resolve: {
|
|
||||||
fullySpecified: false,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
test: /\.css$/,
|
test: /\.css$/,
|
||||||
@@ -79,7 +68,7 @@ const createWebpackConfig = ({
|
|||||||
new TerserPlugin({
|
new TerserPlugin({
|
||||||
parallel: true,
|
parallel: true,
|
||||||
extractComments: true,
|
extractComments: true,
|
||||||
terserOptions: bundle.terserOptions({ latestBuild, isTestBuild }),
|
terserOptions: bundle.terserOptions(latestBuild),
|
||||||
}),
|
}),
|
||||||
],
|
],
|
||||||
moduleIds: isProdBuild && !isStatsBuild ? "deterministic" : "named",
|
moduleIds: isProdBuild && !isStatsBuild ? "deterministic" : "named",
|
||||||
@@ -152,37 +141,18 @@ const createWebpackConfig = ({
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
output: {
|
output: {
|
||||||
filename: ({ chunk }) =>
|
filename: ({ chunk }) => {
|
||||||
!isProdBuild || isStatsBuild || dontHash.has(chunk.name)
|
if (!isProdBuild || isStatsBuild || dontHash.has(chunk.name)) {
|
||||||
? "[name].js"
|
return `${chunk.name}.js`;
|
||||||
: "[name]-[contenthash].js",
|
}
|
||||||
|
return `${chunk.name}.${chunk.hash.substr(0, 8)}.js`;
|
||||||
|
},
|
||||||
chunkFilename:
|
chunkFilename:
|
||||||
isProdBuild && !isStatsBuild ? "[id]-[contenthash].js" : "[name].js",
|
isProdBuild && !isStatsBuild ? "[chunkhash:8].js" : "[id].chunk.js",
|
||||||
assetModuleFilename:
|
|
||||||
isProdBuild && !isStatsBuild ? "[id]-[contenthash][ext]" : "[id][ext]",
|
|
||||||
hashFunction: "xxhash64",
|
|
||||||
hashDigest: "base64url",
|
|
||||||
hashDigestLength: 11, // full length of 64 bit base64url
|
|
||||||
path: outputPath,
|
path: outputPath,
|
||||||
publicPath,
|
publicPath,
|
||||||
// To silence warning in worker plugin
|
// To silence warning in worker plugin
|
||||||
globalObject: "self",
|
globalObject: "self",
|
||||||
// Since production source maps don't include sources, we need to point to them elsewhere
|
|
||||||
// For dependencies, just provide the path (no source in browser)
|
|
||||||
// Otherwise, point to the raw code on GitHub for browser to load
|
|
||||||
devtoolModuleFilenameTemplate:
|
|
||||||
!isTestBuild && isProdBuild
|
|
||||||
? (info) => {
|
|
||||||
const sourcePath = info.resourcePath.replace(/^\.\//, "");
|
|
||||||
if (
|
|
||||||
sourcePath.startsWith("node_modules") ||
|
|
||||||
sourcePath.startsWith("webpack")
|
|
||||||
) {
|
|
||||||
return `no-source/${sourcePath}`;
|
|
||||||
}
|
|
||||||
return `${bundle.sourceMapURL()}/${sourcePath}`;
|
|
||||||
}
|
|
||||||
: undefined,
|
|
||||||
},
|
},
|
||||||
experiments: {
|
experiments: {
|
||||||
topLevelAwait: true,
|
topLevelAwait: true,
|
||||||
@@ -190,14 +160,9 @@ const createWebpackConfig = ({
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
const createAppConfig = ({
|
const createAppConfig = ({ isProdBuild, latestBuild, isStatsBuild }) =>
|
||||||
isProdBuild,
|
|
||||||
latestBuild,
|
|
||||||
isStatsBuild,
|
|
||||||
isTestBuild,
|
|
||||||
}) =>
|
|
||||||
createWebpackConfig(
|
createWebpackConfig(
|
||||||
bundle.config.app({ isProdBuild, latestBuild, isStatsBuild, isTestBuild })
|
bundle.config.app({ isProdBuild, latestBuild, isStatsBuild })
|
||||||
);
|
);
|
||||||
|
|
||||||
const createDemoConfig = ({ isProdBuild, latestBuild, isStatsBuild }) =>
|
const createDemoConfig = ({ isProdBuild, latestBuild, isStatsBuild }) =>
|
||||||
@@ -208,20 +173,8 @@ const createDemoConfig = ({ isProdBuild, latestBuild, isStatsBuild }) =>
|
|||||||
const createCastConfig = ({ isProdBuild, latestBuild }) =>
|
const createCastConfig = ({ isProdBuild, latestBuild }) =>
|
||||||
createWebpackConfig(bundle.config.cast({ isProdBuild, latestBuild }));
|
createWebpackConfig(bundle.config.cast({ isProdBuild, latestBuild }));
|
||||||
|
|
||||||
const createHassioConfig = ({
|
const createHassioConfig = ({ isProdBuild, latestBuild }) =>
|
||||||
isProdBuild,
|
createWebpackConfig(bundle.config.hassio({ isProdBuild, latestBuild }));
|
||||||
latestBuild,
|
|
||||||
isStatsBuild,
|
|
||||||
isTestBuild,
|
|
||||||
}) =>
|
|
||||||
createWebpackConfig(
|
|
||||||
bundle.config.hassio({
|
|
||||||
isProdBuild,
|
|
||||||
latestBuild,
|
|
||||||
isStatsBuild,
|
|
||||||
isTestBuild,
|
|
||||||
})
|
|
||||||
);
|
|
||||||
|
|
||||||
const createGalleryConfig = ({ isProdBuild, latestBuild }) =>
|
const createGalleryConfig = ({ isProdBuild, latestBuild }) =>
|
||||||
createWebpackConfig(bundle.config.gallery({ isProdBuild, latestBuild }));
|
createWebpackConfig(bundle.config.gallery({ isProdBuild, latestBuild }));
|
@@ -1,5 +1,5 @@
|
|||||||
import rollup from "../build-scripts/rollup.cjs";
|
const rollup = require("../build-scripts/rollup.js");
|
||||||
import env from "../build-scripts/env.cjs";
|
const env = require("../build-scripts/env.js");
|
||||||
|
|
||||||
const config = rollup.createCastConfig({
|
const config = rollup.createCastConfig({
|
||||||
isProdBuild: env.isProdBuild(),
|
isProdBuild: env.isProdBuild(),
|
||||||
@@ -7,4 +7,4 @@ const config = rollup.createCastConfig({
|
|||||||
isStatsBuild: env.isStatsBuild(),
|
isStatsBuild: env.isStatsBuild(),
|
||||||
});
|
});
|
||||||
|
|
||||||
export default { ...config.inputOptions, output: config.outputOptions };
|
module.exports = { ...config.inputOptions, output: config.outputOptions };
|
||||||
|
@@ -181,7 +181,7 @@ class HcCast extends LitElement {
|
|||||||
private async _handlePickView(ev: Event) {
|
private async _handlePickView(ev: Event) {
|
||||||
const path = (ev.currentTarget as any).getAttribute("data-path");
|
const path = (ev.currentTarget as any).getAttribute("data-path");
|
||||||
await ensureConnectedCastSession(this.castManager!, this.auth!);
|
await ensureConnectedCastSession(this.castManager!, this.auth!);
|
||||||
castSendShowLovelaceView(this.castManager, this.auth.data.hassUrl, path);
|
castSendShowLovelaceView(this.castManager, path, this.auth.data.hassUrl);
|
||||||
}
|
}
|
||||||
|
|
||||||
private async _handleLogout() {
|
private async _handleLogout() {
|
||||||
|
@@ -22,11 +22,7 @@ class HcLayout extends LitElement {
|
|||||||
return html`
|
return html`
|
||||||
<ha-card>
|
<ha-card>
|
||||||
<div class="layout">
|
<div class="layout">
|
||||||
<img
|
<img class="hero" src="/images/google-nest-hub.png" />
|
||||||
class="hero"
|
|
||||||
alt="A Google Nest Hub with a Home Assistant dashboard on its screen"
|
|
||||||
src="/images/google-nest-hub.png"
|
|
||||||
/>
|
|
||||||
<h1 class="card-header">
|
<h1 class="card-header">
|
||||||
Home Assistant Cast${this.subtitle ? ` – ${this.subtitle}` : ""}
|
Home Assistant Cast${this.subtitle ? ` – ${this.subtitle}` : ""}
|
||||||
${this.auth
|
${this.auth
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
import { html, nothing } from "lit";
|
import { html, TemplateResult } from "lit";
|
||||||
import { customElement, property, state } from "lit/decorators";
|
import { customElement, property, state } from "lit/decorators";
|
||||||
import { mockHistory } from "../../../../demo/src/stubs/history";
|
import { mockHistory } from "../../../../demo/src/stubs/history";
|
||||||
import { LovelaceConfig } from "../../../../src/data/lovelace";
|
import { LovelaceConfig } from "../../../../src/data/lovelace";
|
||||||
@@ -18,9 +18,9 @@ class HcDemo extends HassElement {
|
|||||||
|
|
||||||
@state() private _lovelaceConfig?: LovelaceConfig;
|
@state() private _lovelaceConfig?: LovelaceConfig;
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (!this._lovelaceConfig) {
|
if (!this._lovelaceConfig) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
return html`
|
return html`
|
||||||
<hc-lovelace
|
<hc-lovelace
|
||||||
|
@@ -12,7 +12,6 @@ class HcLaunchScreen extends LitElement {
|
|||||||
return html`
|
return html`
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<img
|
<img
|
||||||
alt="Home Assistant logo on left, Nabu Casa logo on right, and red heart in center"
|
|
||||||
src="https://www.home-assistant.io/images/blog/2018-09-thinking-big/social.png"
|
src="https://www.home-assistant.io/images/blog/2018-09-thinking-big/social.png"
|
||||||
/>
|
/>
|
||||||
<div class="status">
|
<div class="status">
|
||||||
|
@@ -252,22 +252,6 @@ export class HcMain extends HassElement {
|
|||||||
msg.urlPath = null;
|
msg.urlPath = null;
|
||||||
}
|
}
|
||||||
this._lovelacePath = msg.viewPath;
|
this._lovelacePath = msg.viewPath;
|
||||||
if (msg.urlPath === "energy") {
|
|
||||||
this._lovelaceConfig = {
|
|
||||||
views: [
|
|
||||||
{
|
|
||||||
strategy: {
|
|
||||||
type: "energy",
|
|
||||||
options: { show_date_selection: true },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
],
|
|
||||||
};
|
|
||||||
this._urlPath = "energy";
|
|
||||||
this._lovelacePath = 0;
|
|
||||||
this._sendStatus();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (!this._unsubLovelace || this._urlPath !== msg.urlPath) {
|
if (!this._unsubLovelace || this._urlPath !== msg.urlPath) {
|
||||||
this._urlPath = msg.urlPath;
|
this._urlPath = msg.urlPath;
|
||||||
this._lovelaceConfig = undefined;
|
this._lovelaceConfig = undefined;
|
||||||
|
@@ -1,8 +1,8 @@
|
|||||||
import webpack from "../build-scripts/webpack.cjs";
|
const { createCastConfig } = require("../build-scripts/webpack.js");
|
||||||
import env from "../build-scripts/env.cjs";
|
const { isProdBuild, isStatsBuild } = require("../build-scripts/env.js");
|
||||||
|
|
||||||
export default webpack.createCastConfig({
|
module.exports = createCastConfig({
|
||||||
isProdBuild: env.isProdBuild(),
|
isProdBuild: isProdBuild(),
|
||||||
isStatsBuild: env.isStatsBuild(),
|
isStatsBuild: isStatsBuild(),
|
||||||
latestBuild: true,
|
latestBuild: true,
|
||||||
});
|
});
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
import rollup from "../build-scripts/rollup.cjs";
|
const rollup = require("../build-scripts/rollup.js");
|
||||||
import env from "../build-scripts/env.cjs";
|
const env = require("../build-scripts/env.js");
|
||||||
|
|
||||||
const config = rollup.createDemoConfig({
|
const config = rollup.createDemoConfig({
|
||||||
isProdBuild: env.isProdBuild(),
|
isProdBuild: env.isProdBuild(),
|
||||||
@@ -7,4 +7,4 @@ const config = rollup.createDemoConfig({
|
|||||||
isStatsBuild: env.isStatsBuild(),
|
isStatsBuild: env.isStatsBuild(),
|
||||||
});
|
});
|
||||||
|
|
||||||
export default { ...config.inputOptions, output: config.outputOptions };
|
module.exports = { ...config.inputOptions, output: config.outputOptions };
|
||||||
|
@@ -6,9 +6,6 @@ set -e
|
|||||||
|
|
||||||
cd "$(dirname "$0")/.."
|
cd "$(dirname "$0")/.."
|
||||||
|
|
||||||
export STATS=1
|
STATS=1 NODE_ENV=production ../node_modules/.bin/webpack --profile --json > compilation-stats.json
|
||||||
statsfile="compilation-stats-demo.json"
|
npx webpack-bundle-analyzer compilation-stats.json dist/frontend_latest
|
||||||
|
rm compilation-stats.json
|
||||||
./node_modules/.bin/webpack-cli --profile --node-env=production --json=$statsfile
|
|
||||||
npx webpack-bundle-analyzer $statsfile dist/frontend_latest
|
|
||||||
rm -f $statsfile
|
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
import { mdiTelevision } from "@mdi/js";
|
import { mdiTelevision } from "@mdi/js";
|
||||||
import { css, CSSResultGroup, html, LitElement, nothing } from "lit";
|
import { css, CSSResultGroup, html, LitElement, TemplateResult } from "lit";
|
||||||
import { customElement, state } from "lit/decorators";
|
import { customElement, state } from "lit/decorators";
|
||||||
import { CastManager } from "../../../src/cast/cast_manager";
|
import { CastManager } from "../../../src/cast/cast_manager";
|
||||||
import { castSendShowDemo } from "../../../src/cast/receiver_messages";
|
import { castSendShowDemo } from "../../../src/cast/receiver_messages";
|
||||||
@@ -20,12 +20,12 @@ class CastDemoRow extends LitElement implements LovelaceRow {
|
|||||||
// No config possible.
|
// No config possible.
|
||||||
}
|
}
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (
|
if (
|
||||||
!this._castManager ||
|
!this._castManager ||
|
||||||
this._castManager.castState === "NO_DEVICES_AVAILABLE"
|
this._castManager.castState === "NO_DEVICES_AVAILABLE"
|
||||||
) {
|
) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
return html`
|
return html`
|
||||||
<ha-svg-icon .path=${mdiTelevision}></ha-svg-icon>
|
<ha-svg-icon .path=${mdiTelevision}></ha-svg-icon>
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
import "@material/mwc-button";
|
import "@material/mwc-button";
|
||||||
import { css, CSSResultGroup, html, LitElement, nothing } from "lit";
|
import { css, CSSResultGroup, html, LitElement, TemplateResult } from "lit";
|
||||||
import { customElement, property, state } from "lit/decorators";
|
import { property, state } from "lit/decorators";
|
||||||
import { until } from "lit/directives/until";
|
import { until } from "lit/directives/until";
|
||||||
import "../../../src/components/ha-card";
|
import "../../../src/components/ha-card";
|
||||||
import "../../../src/components/ha-circular-progress";
|
import "../../../src/components/ha-circular-progress";
|
||||||
@@ -14,7 +14,6 @@ import {
|
|||||||
setDemoConfig,
|
setDemoConfig,
|
||||||
} from "../configs/demo-configs";
|
} from "../configs/demo-configs";
|
||||||
|
|
||||||
@customElement("ha-demo-card")
|
|
||||||
export class HADemoCard extends LitElement implements LovelaceCard {
|
export class HADemoCard extends LitElement implements LovelaceCard {
|
||||||
@property({ attribute: false }) public lovelace?: Lovelace;
|
@property({ attribute: false }) public lovelace?: Lovelace;
|
||||||
|
|
||||||
@@ -30,9 +29,9 @@ export class HADemoCard extends LitElement implements LovelaceCard {
|
|||||||
|
|
||||||
public setConfig(_config: LovelaceCardConfig) {}
|
public setConfig(_config: LovelaceCardConfig) {}
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (this._hidden) {
|
if (this._hidden) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
return html`
|
return html`
|
||||||
<ha-card>
|
<ha-card>
|
||||||
@@ -155,3 +154,5 @@ declare global {
|
|||||||
"ha-demo-card": HADemoCard;
|
"ha-demo-card": HADemoCard;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
customElements.define("ha-demo-card", HADemoCard);
|
||||||
|
@@ -1,6 +1,4 @@
|
|||||||
// Compat needs to be first import
|
// Compat needs to be first import
|
||||||
import "../../src/resources/compatibility";
|
|
||||||
import { customElement } from "lit/decorators";
|
|
||||||
import { isNavigationClick } from "../../src/common/dom/is-navigation-click";
|
import { isNavigationClick } from "../../src/common/dom/is-navigation-click";
|
||||||
import { navigate } from "../../src/common/navigate";
|
import { navigate } from "../../src/common/navigate";
|
||||||
import {
|
import {
|
||||||
@@ -8,6 +6,7 @@ import {
|
|||||||
provideHass,
|
provideHass,
|
||||||
} from "../../src/fake_data/provide_hass";
|
} from "../../src/fake_data/provide_hass";
|
||||||
import { HomeAssistantAppEl } from "../../src/layouts/home-assistant";
|
import { HomeAssistantAppEl } from "../../src/layouts/home-assistant";
|
||||||
|
import "../../src/resources/compatibility";
|
||||||
import { HomeAssistant } from "../../src/types";
|
import { HomeAssistant } from "../../src/types";
|
||||||
import { selectedDemoConfig } from "./configs/demo-configs";
|
import { selectedDemoConfig } from "./configs/demo-configs";
|
||||||
import { mockAuth } from "./stubs/auth";
|
import { mockAuth } from "./stubs/auth";
|
||||||
@@ -27,8 +26,7 @@ import { mockSystemLog } from "./stubs/system_log";
|
|||||||
import { mockTemplate } from "./stubs/template";
|
import { mockTemplate } from "./stubs/template";
|
||||||
import { mockTranslations } from "./stubs/translations";
|
import { mockTranslations } from "./stubs/translations";
|
||||||
|
|
||||||
@customElement("ha-demo")
|
class HaDemo extends HomeAssistantAppEl {
|
||||||
export class HaDemo extends HomeAssistantAppEl {
|
|
||||||
protected async _initializeHass() {
|
protected async _initializeHass() {
|
||||||
const initial: Partial<MockHomeAssistant> = {
|
const initial: Partial<MockHomeAssistant> = {
|
||||||
panelUrl: (this as any)._panelUrl,
|
panelUrl: (this as any)._panelUrl,
|
||||||
@@ -73,7 +71,6 @@ export class HaDemo extends HomeAssistantAppEl {
|
|||||||
entity_category: null,
|
entity_category: null,
|
||||||
has_entity_name: false,
|
has_entity_name: false,
|
||||||
unique_id: "co2_intensity",
|
unique_id: "co2_intensity",
|
||||||
options: null,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
config_entry_id: "co2signal",
|
config_entry_id: "co2signal",
|
||||||
@@ -89,7 +86,6 @@ export class HaDemo extends HomeAssistantAppEl {
|
|||||||
entity_category: null,
|
entity_category: null,
|
||||||
has_entity_name: false,
|
has_entity_name: false,
|
||||||
unique_id: "grid_fossil_fuel_percentage",
|
unique_id: "grid_fossil_fuel_percentage",
|
||||||
options: null,
|
|
||||||
},
|
},
|
||||||
]);
|
]);
|
||||||
|
|
||||||
@@ -125,6 +121,8 @@ export class HaDemo extends HomeAssistantAppEl {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
customElements.define("ha-demo", HaDemo);
|
||||||
|
|
||||||
declare global {
|
declare global {
|
||||||
interface HTMLElementTagNameMap {
|
interface HTMLElementTagNameMap {
|
||||||
"ha-demo": HaDemo;
|
"ha-demo": HaDemo;
|
||||||
|
@@ -1,19 +1,39 @@
|
|||||||
import { HassEntity } from "home-assistant-js-websocket";
|
import { HassEntity } from "home-assistant-js-websocket";
|
||||||
import { HistoryStates } from "../../../src/data/history";
|
|
||||||
import { MockHomeAssistant } from "../../../src/fake_data/provide_hass";
|
import { MockHomeAssistant } from "../../../src/fake_data/provide_hass";
|
||||||
|
|
||||||
const generateStateHistory = (
|
interface HistoryQueryParams {
|
||||||
state: HassEntity,
|
filter_entity_id: string;
|
||||||
deltas,
|
end_time: string;
|
||||||
start_date: Date,
|
}
|
||||||
end_date: Date
|
|
||||||
) => {
|
const parseQuery = <T>(queryString: string) => {
|
||||||
|
const query: any = {};
|
||||||
|
const items = queryString.split("&");
|
||||||
|
for (const item of items) {
|
||||||
|
const parts = item.split("=");
|
||||||
|
const key = decodeURIComponent(parts[0]);
|
||||||
|
const value = parts.length > 1 ? decodeURIComponent(parts[1]) : undefined;
|
||||||
|
query[key] = value;
|
||||||
|
}
|
||||||
|
return query as T;
|
||||||
|
};
|
||||||
|
|
||||||
|
const getTime = (minutesAgo) => {
|
||||||
|
const ts = new Date(Date.now() - minutesAgo * 60 * 1000);
|
||||||
|
return ts.toISOString();
|
||||||
|
};
|
||||||
|
|
||||||
|
const randomTimeAdjustment = (diff) => Math.random() * diff - diff / 2;
|
||||||
|
|
||||||
|
const maxTime = 1440;
|
||||||
|
|
||||||
|
const generateHistory = (state, deltas) => {
|
||||||
const changes =
|
const changes =
|
||||||
typeof deltas[0] === "object"
|
typeof deltas[0] === "object"
|
||||||
? deltas
|
? deltas
|
||||||
: deltas.map((st) => ({ state: st }));
|
: deltas.map((st) => ({ state: st }));
|
||||||
|
|
||||||
const timeDiff = (end_date.getTime() - start_date.getTime()) / changes.length;
|
const timeDiff = 900 / changes.length;
|
||||||
|
|
||||||
return changes.map((change, index) => {
|
return changes.map((change, index) => {
|
||||||
let attributes;
|
let attributes;
|
||||||
@@ -27,13 +47,17 @@ const generateStateHistory = (
|
|||||||
attributes = { ...state.attributes, ...change.attributes };
|
attributes = { ...state.attributes, ...change.attributes };
|
||||||
}
|
}
|
||||||
|
|
||||||
const time = start_date.getTime() + timeDiff * index;
|
const time =
|
||||||
|
index === 0
|
||||||
|
? getTime(maxTime)
|
||||||
|
: getTime(maxTime - index * timeDiff + randomTimeAdjustment(timeDiff));
|
||||||
|
|
||||||
return {
|
return {
|
||||||
a: attributes,
|
attributes,
|
||||||
s: change.state || state.state,
|
entity_id: state.entity_id,
|
||||||
lc: time / 1000,
|
state: change.state || state.state,
|
||||||
lu: time / 1000,
|
last_changed: time,
|
||||||
|
last_updated: time,
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
@@ -41,29 +65,15 @@ const generateStateHistory = (
|
|||||||
const incrementalUnits = ["clients", "queries", "ads"];
|
const incrementalUnits = ["clients", "queries", "ads"];
|
||||||
|
|
||||||
export const mockHistory = (mockHass: MockHomeAssistant) => {
|
export const mockHistory = (mockHass: MockHomeAssistant) => {
|
||||||
mockHass.mockWS(
|
mockHass.mockAPI(
|
||||||
"history/stream",
|
new RegExp("history/period/.+"),
|
||||||
(
|
(hass, _method, path, _parameters) => {
|
||||||
{
|
const params = parseQuery<HistoryQueryParams>(path.split("?")[1]);
|
||||||
entity_ids,
|
const entities = params.filter_entity_id.split(",");
|
||||||
start_time,
|
|
||||||
end_time,
|
|
||||||
}: {
|
|
||||||
entity_ids: string[];
|
|
||||||
start_time: string;
|
|
||||||
end_time?: string;
|
|
||||||
},
|
|
||||||
hass,
|
|
||||||
onChange
|
|
||||||
) => {
|
|
||||||
const states: HistoryStates = {};
|
|
||||||
|
|
||||||
const start = new Date(start_time);
|
const results: HassEntity[][] = [];
|
||||||
const end = end_time ? new Date(end_time) : new Date();
|
|
||||||
|
|
||||||
for (const entityId of entity_ids) {
|
|
||||||
states[entityId] = [];
|
|
||||||
|
|
||||||
|
for (const entityId of entities) {
|
||||||
const state = hass.states[entityId];
|
const state = hass.states[entityId];
|
||||||
|
|
||||||
if (!state) {
|
if (!state) {
|
||||||
@@ -71,12 +81,7 @@ export const mockHistory = (mockHass: MockHomeAssistant) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!state.attributes.unit_of_measurement) {
|
if (!state.attributes.unit_of_measurement) {
|
||||||
states[entityId] = generateStateHistory(
|
results.push(generateHistory(state, [state.state]));
|
||||||
state,
|
|
||||||
[state.state],
|
|
||||||
start,
|
|
||||||
end
|
|
||||||
);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -115,23 +120,17 @@ export const mockHistory = (mockHass: MockHomeAssistant) => {
|
|||||||
numberState - diff + Math.floor(Math.random() * 2 * diff);
|
numberState - diff + Math.floor(Math.random() * 2 * diff);
|
||||||
}
|
}
|
||||||
|
|
||||||
states[entityId] = generateStateHistory(
|
results.push(
|
||||||
state,
|
generateHistory(
|
||||||
Array.from({ length: statesToGenerate }, genFunc),
|
{
|
||||||
start,
|
entity_id: state.entity_id,
|
||||||
end
|
attributes: state.attributes,
|
||||||
|
},
|
||||||
|
Array.from({ length: statesToGenerate }, genFunc)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
return results;
|
||||||
setTimeout(() => {
|
|
||||||
onChange?.({
|
|
||||||
states,
|
|
||||||
start_time: start,
|
|
||||||
end_time: end,
|
|
||||||
});
|
|
||||||
}, 1);
|
|
||||||
|
|
||||||
return () => {};
|
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@@ -15,7 +15,6 @@ import { MockHomeAssistant } from "../../../src/fake_data/provide_hass";
|
|||||||
const generateMeanStatistics = (
|
const generateMeanStatistics = (
|
||||||
start: Date,
|
start: Date,
|
||||||
end: Date,
|
end: Date,
|
||||||
// eslint-disable-next-line @typescript-eslint/default-param-last
|
|
||||||
period: "5minute" | "hour" | "day" | "month" = "hour",
|
period: "5minute" | "hour" | "day" | "month" = "hour",
|
||||||
initValue: number,
|
initValue: number,
|
||||||
maxDiff: number
|
maxDiff: number
|
||||||
@@ -52,7 +51,6 @@ const generateMeanStatistics = (
|
|||||||
const generateSumStatistics = (
|
const generateSumStatistics = (
|
||||||
start: Date,
|
start: Date,
|
||||||
end: Date,
|
end: Date,
|
||||||
// eslint-disable-next-line @typescript-eslint/default-param-last
|
|
||||||
period: "5minute" | "hour" | "day" | "month" = "hour",
|
period: "5minute" | "hour" | "day" | "month" = "hour",
|
||||||
initValue: number,
|
initValue: number,
|
||||||
maxDiff: number
|
maxDiff: number
|
||||||
@@ -88,7 +86,6 @@ const generateSumStatistics = (
|
|||||||
const generateCurvedStatistics = (
|
const generateCurvedStatistics = (
|
||||||
start: Date,
|
start: Date,
|
||||||
end: Date,
|
end: Date,
|
||||||
// eslint-disable-next-line @typescript-eslint/default-param-last
|
|
||||||
_period: "5minute" | "hour" | "day" | "month" = "hour",
|
_period: "5minute" | "hour" | "day" | "month" = "hour",
|
||||||
initValue: number,
|
initValue: number,
|
||||||
maxDiff: number,
|
maxDiff: number,
|
||||||
|
@@ -1,11 +1,12 @@
|
|||||||
import webpack from "../build-scripts/webpack.cjs";
|
const { createDemoConfig } = require("../build-scripts/webpack.js");
|
||||||
import env from "../build-scripts/env.cjs";
|
const { isProdBuild, isStatsBuild } = require("../build-scripts/env.js");
|
||||||
|
|
||||||
// File just used for stats builds
|
// File just used for stats builds
|
||||||
|
|
||||||
const latestBuild = true;
|
const latestBuild = true;
|
||||||
|
|
||||||
export default webpack.createDemoConfig({
|
module.exports = createDemoConfig({
|
||||||
isProdBuild: env.isProdBuild(),
|
isProdBuild: isProdBuild(),
|
||||||
isStatsBuild: env.isStatsBuild(),
|
isStatsBuild: isStatsBuild(),
|
||||||
latestBuild,
|
latestBuild,
|
||||||
});
|
});
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
import rollup from "../build-scripts/rollup.cjs";
|
const rollup = require("../build-scripts/rollup.js");
|
||||||
import env from "../build-scripts/env.cjs";
|
const env = require("../build-scripts/env.js");
|
||||||
|
|
||||||
const config = rollup.createGalleryConfig({
|
const config = rollup.createGalleryConfig({
|
||||||
isProdBuild: env.isProdBuild(),
|
isProdBuild: env.isProdBuild(),
|
||||||
@@ -7,4 +7,4 @@ const config = rollup.createGalleryConfig({
|
|||||||
isStatsBuild: env.isStatsBuild(),
|
isStatsBuild: env.isStatsBuild(),
|
||||||
});
|
});
|
||||||
|
|
||||||
export default { ...config.inputOptions, output: config.outputOptions };
|
module.exports = { ...config.inputOptions, output: config.outputOptions };
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
export default [
|
module.exports = [
|
||||||
{
|
{
|
||||||
// This section has no header and so all page links are shown directly in the sidebar
|
// This section has no header and so all page links are shown directly in the sidebar
|
||||||
category: "concepts",
|
category: "concepts",
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
import { css, html, nothing } from "lit";
|
import { html, css } from "lit";
|
||||||
import { customElement, property } from "lit/decorators";
|
import { customElement, property } from "lit/decorators";
|
||||||
import { until } from "lit/directives/until";
|
import { until } from "lit/directives/until";
|
||||||
import { HaMarkdown } from "../../../src/components/ha-markdown";
|
import { HaMarkdown } from "../../../src/components/ha-markdown";
|
||||||
@@ -10,7 +10,7 @@ class PageDescription extends HaMarkdown {
|
|||||||
|
|
||||||
render() {
|
render() {
|
||||||
if (!PAGES[this.page].description) {
|
if (!PAGES[this.page].description) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
|
|
||||||
return html`
|
return html`
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
import { dump } from "js-yaml";
|
import { dump } from "js-yaml";
|
||||||
import { css, html, LitElement, nothing } from "lit";
|
import { html, css, LitElement, TemplateResult } from "lit";
|
||||||
import { customElement, property, state } from "lit/decorators";
|
import { customElement, property, state } from "lit/decorators";
|
||||||
import "../../../../src/components/ha-card";
|
import "../../../../src/components/ha-card";
|
||||||
import "../../../../src/components/ha-yaml-editor";
|
import "../../../../src/components/ha-yaml-editor";
|
||||||
@@ -127,16 +127,16 @@ export class DemoAutomationDescribeAction extends LitElement {
|
|||||||
|
|
||||||
@state() _action = initialAction;
|
@state() _action = initialAction;
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (!this.hass) {
|
if (!this.hass) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
return html`
|
return html`
|
||||||
<ha-card header="Actions">
|
<ha-card header="Actions">
|
||||||
<div class="action">
|
<div class="action">
|
||||||
<span>
|
<span>
|
||||||
${this._action
|
${this._action
|
||||||
? describeAction(this.hass, [], this._action)
|
? describeAction(this.hass, this._action)
|
||||||
: "<invalid YAML>"}
|
: "<invalid YAML>"}
|
||||||
</span>
|
</span>
|
||||||
<ha-yaml-editor
|
<ha-yaml-editor
|
||||||
@@ -149,7 +149,7 @@ export class DemoAutomationDescribeAction extends LitElement {
|
|||||||
${ACTIONS.map(
|
${ACTIONS.map(
|
||||||
(conf) => html`
|
(conf) => html`
|
||||||
<div class="action">
|
<div class="action">
|
||||||
<span>${describeAction(this.hass, [], conf as any)}</span>
|
<span>${describeAction(this.hass, conf as any)}</span>
|
||||||
<pre>${dump(conf)}</pre>
|
<pre>${dump(conf)}</pre>
|
||||||
</div>
|
</div>
|
||||||
`
|
`
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
import { dump } from "js-yaml";
|
import { dump } from "js-yaml";
|
||||||
import { css, html, LitElement, nothing } from "lit";
|
import { css, html, LitElement, TemplateResult } from "lit";
|
||||||
import { customElement, property, state } from "lit/decorators";
|
import { customElement, property, state } from "lit/decorators";
|
||||||
import "../../../../src/components/ha-card";
|
import "../../../../src/components/ha-card";
|
||||||
import "../../../../src/components/ha-yaml-editor";
|
import "../../../../src/components/ha-yaml-editor";
|
||||||
@@ -53,9 +53,9 @@ export class DemoAutomationDescribeCondition extends LitElement {
|
|||||||
|
|
||||||
@state() _condition = initialCondition;
|
@state() _condition = initialCondition;
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (!this.hass) {
|
if (!this.hass) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
|
|
||||||
return html`
|
return html`
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
import { dump } from "js-yaml";
|
import { dump } from "js-yaml";
|
||||||
import { css, html, LitElement, nothing } from "lit";
|
import { css, html, LitElement, TemplateResult } from "lit";
|
||||||
import { customElement, property, state } from "lit/decorators";
|
import { customElement, property, state } from "lit/decorators";
|
||||||
import "../../../../src/components/ha-card";
|
import "../../../../src/components/ha-card";
|
||||||
import "../../../../src/components/ha-yaml-editor";
|
import "../../../../src/components/ha-yaml-editor";
|
||||||
@@ -64,9 +64,9 @@ export class DemoAutomationDescribeTrigger extends LitElement {
|
|||||||
|
|
||||||
@state() _trigger = initialTrigger;
|
@state() _trigger = initialTrigger;
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (!this.hass) {
|
if (!this.hass) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
|
|
||||||
return html`
|
return html`
|
||||||
|
@@ -1,6 +1,5 @@
|
|||||||
/* eslint-disable lit/no-template-arrow */
|
/* eslint-disable lit/no-template-arrow */
|
||||||
|
import { html, css, LitElement, TemplateResult } from "lit";
|
||||||
import { css, html, LitElement, nothing } from "lit";
|
|
||||||
import { customElement, property } from "lit/decorators";
|
import { customElement, property } from "lit/decorators";
|
||||||
import "../../../../src/components/ha-card";
|
import "../../../../src/components/ha-card";
|
||||||
import "../../../../src/components/trace/hat-script-graph";
|
import "../../../../src/components/trace/hat-script-graph";
|
||||||
@@ -30,9 +29,9 @@ const traces: DemoTrace[] = [
|
|||||||
export class DemoAutomationTraceTimeline extends LitElement {
|
export class DemoAutomationTraceTimeline extends LitElement {
|
||||||
@property({ attribute: false }) hass?: HomeAssistant;
|
@property({ attribute: false }) hass?: HomeAssistant;
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (!this.hass) {
|
if (!this.hass) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
return html`
|
return html`
|
||||||
${traces.map(
|
${traces.map(
|
||||||
|
@@ -1,15 +1,14 @@
|
|||||||
/* eslint-disable lit/no-template-arrow */
|
/* eslint-disable lit/no-template-arrow */
|
||||||
|
import { html, css, LitElement, TemplateResult } from "lit";
|
||||||
import { css, html, LitElement, nothing } from "lit";
|
|
||||||
import { customElement, property, state } from "lit/decorators";
|
|
||||||
import "../../../../src/components/ha-card";
|
import "../../../../src/components/ha-card";
|
||||||
import "../../../../src/components/trace/hat-script-graph";
|
import "../../../../src/components/trace/hat-script-graph";
|
||||||
import "../../../../src/components/trace/hat-trace-timeline";
|
import "../../../../src/components/trace/hat-trace-timeline";
|
||||||
|
import { customElement, property, state } from "lit/decorators";
|
||||||
import { provideHass } from "../../../../src/fake_data/provide_hass";
|
import { provideHass } from "../../../../src/fake_data/provide_hass";
|
||||||
import { HomeAssistant } from "../../../../src/types";
|
import { HomeAssistant } from "../../../../src/types";
|
||||||
|
import { DemoTrace } from "../../data/traces/types";
|
||||||
import { basicTrace } from "../../data/traces/basic_trace";
|
import { basicTrace } from "../../data/traces/basic_trace";
|
||||||
import { motionLightTrace } from "../../data/traces/motion-light-trace";
|
import { motionLightTrace } from "../../data/traces/motion-light-trace";
|
||||||
import { DemoTrace } from "../../data/traces/types";
|
|
||||||
|
|
||||||
const traces: DemoTrace[] = [basicTrace, motionLightTrace];
|
const traces: DemoTrace[] = [basicTrace, motionLightTrace];
|
||||||
|
|
||||||
@@ -19,9 +18,9 @@ export class DemoAutomationTrace extends LitElement {
|
|||||||
|
|
||||||
@state() private _selected = {};
|
@state() private _selected = {};
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (!this.hass) {
|
if (!this.hass) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
return html`
|
return html`
|
||||||
${traces.map(
|
${traces.map(
|
||||||
|
@@ -156,6 +156,18 @@ The `title ` option should not be used without a description.
|
|||||||
|
|
||||||
*Documentation coming soon*
|
*Documentation coming soon*
|
||||||
|
|
||||||
|
**Right to left**
|
||||||
|
|
||||||
|
<ha-alert alert-type="success" rtl>
|
||||||
|
This is an info alert — check it out!
|
||||||
|
</ha-alert>
|
||||||
|
|
||||||
|
```html
|
||||||
|
<ha-alert alert-type="success" rtl>
|
||||||
|
This is an info alert — check it out!
|
||||||
|
</ha-alert>
|
||||||
|
```
|
||||||
|
|
||||||
### API
|
### API
|
||||||
**Properties/Attributes**
|
**Properties/Attributes**
|
||||||
|
|
||||||
|
3
gallery/src/pages/components/ha-bar-slider.markdown
Normal file
3
gallery/src/pages/components/ha-bar-slider.markdown
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
---
|
||||||
|
title: Bar Slider
|
||||||
|
---
|
@@ -2,7 +2,7 @@ import { css, html, LitElement, TemplateResult } from "lit";
|
|||||||
import { customElement, state } from "lit/decorators";
|
import { customElement, state } from "lit/decorators";
|
||||||
import { ifDefined } from "lit/directives/if-defined";
|
import { ifDefined } from "lit/directives/if-defined";
|
||||||
import { repeat } from "lit/directives/repeat";
|
import { repeat } from "lit/directives/repeat";
|
||||||
import "../../../../src/components/ha-control-slider";
|
import "../../../../src/components/ha-bar-slider";
|
||||||
import "../../../../src/components/ha-card";
|
import "../../../../src/components/ha-card";
|
||||||
|
|
||||||
const sliders: {
|
const sliders: {
|
||||||
@@ -46,7 +46,7 @@ const sliders: {
|
|||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
@customElement("demo-components-ha-control-slider")
|
@customElement("demo-components-ha-bar-slider")
|
||||||
export class DemoHaBarSlider extends LitElement {
|
export class DemoHaBarSlider extends LitElement {
|
||||||
@state() private value = 50;
|
@state() private value = 50;
|
||||||
|
|
||||||
@@ -86,7 +86,7 @@ export class DemoHaBarSlider extends LitElement {
|
|||||||
<div class="card-content">
|
<div class="card-content">
|
||||||
<label id=${id}>${label}</label>
|
<label id=${id}>${label}</label>
|
||||||
<pre>Config: ${JSON.stringify(config)}</pre>
|
<pre>Config: ${JSON.stringify(config)}</pre>
|
||||||
<ha-control-slider
|
<ha-bar-slider
|
||||||
.value=${this.value}
|
.value=${this.value}
|
||||||
.mode=${config.mode}
|
.mode=${config.mode}
|
||||||
class=${ifDefined(config.class)}
|
class=${ifDefined(config.class)}
|
||||||
@@ -94,7 +94,7 @@ export class DemoHaBarSlider extends LitElement {
|
|||||||
@slider-moved=${this.handleSliderMoved}
|
@slider-moved=${this.handleSliderMoved}
|
||||||
aria-labelledby=${id}
|
aria-labelledby=${id}
|
||||||
>
|
>
|
||||||
</ha-control-slider>
|
</ha-bar-slider>
|
||||||
</div>
|
</div>
|
||||||
</ha-card>
|
</ha-card>
|
||||||
`;
|
`;
|
||||||
@@ -106,7 +106,7 @@ export class DemoHaBarSlider extends LitElement {
|
|||||||
${repeat(sliders, (slider) => {
|
${repeat(sliders, (slider) => {
|
||||||
const { id, label, ...config } = slider;
|
const { id, label, ...config } = slider;
|
||||||
return html`
|
return html`
|
||||||
<ha-control-slider
|
<ha-bar-slider
|
||||||
.value=${this.value}
|
.value=${this.value}
|
||||||
.mode=${config.mode}
|
.mode=${config.mode}
|
||||||
vertical
|
vertical
|
||||||
@@ -115,7 +115,7 @@ export class DemoHaBarSlider extends LitElement {
|
|||||||
@slider-moved=${this.handleSliderMoved}
|
@slider-moved=${this.handleSliderMoved}
|
||||||
aria-label=${label}
|
aria-label=${label}
|
||||||
>
|
>
|
||||||
</ha-control-slider>
|
</ha-bar-slider>
|
||||||
`;
|
`;
|
||||||
})}
|
})}
|
||||||
</div>
|
</div>
|
||||||
@@ -141,11 +141,11 @@ export class DemoHaBarSlider extends LitElement {
|
|||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
}
|
}
|
||||||
.custom {
|
.custom {
|
||||||
--control-slider-color: #ffcf4c;
|
--slider-bar-color: #ffcf4c;
|
||||||
--control-slider-background: #ffcf4c;
|
--slider-bar-background: #ffcf4c;
|
||||||
--control-slider-background-opacity: 0.2;
|
--slider-bar-background-opacity: 0.2;
|
||||||
--control-slider-thickness: 100px;
|
--slider-bar-thickness: 100px;
|
||||||
--control-slider-border-radius: 24px;
|
--slider-bar-border-radius: 24px;
|
||||||
}
|
}
|
||||||
.vertical-sliders {
|
.vertical-sliders {
|
||||||
height: 300px;
|
height: 300px;
|
||||||
@@ -165,6 +165,6 @@ export class DemoHaBarSlider extends LitElement {
|
|||||||
|
|
||||||
declare global {
|
declare global {
|
||||||
interface HTMLElementTagNameMap {
|
interface HTMLElementTagNameMap {
|
||||||
"demo-components-ha-control-slider": DemoHaBarSlider;
|
"demo-components-ha-bar-slider": DemoHaBarSlider;
|
||||||
}
|
}
|
||||||
}
|
}
|
3
gallery/src/pages/components/ha-bar-switch.markdown
Normal file
3
gallery/src/pages/components/ha-bar-switch.markdown
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
---
|
||||||
|
title: Bar Switch
|
||||||
|
---
|
@@ -8,7 +8,7 @@ import { css, html, LitElement, TemplateResult } from "lit";
|
|||||||
import { customElement, state } from "lit/decorators";
|
import { customElement, state } from "lit/decorators";
|
||||||
import { ifDefined } from "lit/directives/if-defined";
|
import { ifDefined } from "lit/directives/if-defined";
|
||||||
import { repeat } from "lit/directives/repeat";
|
import { repeat } from "lit/directives/repeat";
|
||||||
import "../../../../src/components/ha-control-switch";
|
import "../../../../src/components/ha-bar-switch";
|
||||||
import "../../../../src/components/ha-card";
|
import "../../../../src/components/ha-card";
|
||||||
|
|
||||||
const switches: {
|
const switches: {
|
||||||
@@ -39,8 +39,8 @@ const switches: {
|
|||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
@customElement("demo-components-ha-control-switch")
|
@customElement("demo-components-ha-bar-switch")
|
||||||
export class DemoHaControlSwitch extends LitElement {
|
export class DemoHaBarSwitch extends LitElement {
|
||||||
@state() private checked = false;
|
@state() private checked = false;
|
||||||
|
|
||||||
handleValueChanged(e: any) {
|
handleValueChanged(e: any) {
|
||||||
@@ -56,7 +56,7 @@ export class DemoHaControlSwitch extends LitElement {
|
|||||||
<div class="card-content">
|
<div class="card-content">
|
||||||
<label id=${id}>${label}</label>
|
<label id=${id}>${label}</label>
|
||||||
<pre>Config: ${JSON.stringify(config)}</pre>
|
<pre>Config: ${JSON.stringify(config)}</pre>
|
||||||
<ha-control-switch
|
<ha-bar-switch
|
||||||
.checked=${this.checked}
|
.checked=${this.checked}
|
||||||
class=${ifDefined(config.class)}
|
class=${ifDefined(config.class)}
|
||||||
@change=${this.handleValueChanged}
|
@change=${this.handleValueChanged}
|
||||||
@@ -66,7 +66,7 @@ export class DemoHaControlSwitch extends LitElement {
|
|||||||
disabled=${ifDefined(config.disabled)}
|
disabled=${ifDefined(config.disabled)}
|
||||||
reversed=${ifDefined(config.reversed)}
|
reversed=${ifDefined(config.reversed)}
|
||||||
>
|
>
|
||||||
</ha-control-switch>
|
</ha-bar-switch>
|
||||||
</div>
|
</div>
|
||||||
</ha-card>
|
</ha-card>
|
||||||
`;
|
`;
|
||||||
@@ -78,7 +78,7 @@ export class DemoHaControlSwitch extends LitElement {
|
|||||||
${repeat(switches, (sw) => {
|
${repeat(switches, (sw) => {
|
||||||
const { id, label, ...config } = sw;
|
const { id, label, ...config } = sw;
|
||||||
return html`
|
return html`
|
||||||
<ha-control-switch
|
<ha-bar-switch
|
||||||
.checked=${this.checked}
|
.checked=${this.checked}
|
||||||
vertical
|
vertical
|
||||||
class=${ifDefined(config.class)}
|
class=${ifDefined(config.class)}
|
||||||
@@ -89,7 +89,7 @@ export class DemoHaControlSwitch extends LitElement {
|
|||||||
disabled=${ifDefined(config.disabled)}
|
disabled=${ifDefined(config.disabled)}
|
||||||
reversed=${ifDefined(config.reversed)}
|
reversed=${ifDefined(config.reversed)}
|
||||||
>
|
>
|
||||||
</ha-control-switch>
|
</ha-bar-switch>
|
||||||
`;
|
`;
|
||||||
})}
|
})}
|
||||||
</div>
|
</div>
|
||||||
@@ -115,11 +115,11 @@ export class DemoHaControlSwitch extends LitElement {
|
|||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
}
|
}
|
||||||
.custom {
|
.custom {
|
||||||
--control-switch-on-color: var(--green-color);
|
--switch-bar-on-color: rgb(var(--rgb-green-color));
|
||||||
--control-switch-off-color: var(--red-color);
|
--switch-bar-off-color: rgb(var(--rgb-red-color));
|
||||||
--control-switch-thickness: 100px;
|
--switch-bar-thickness: 100px;
|
||||||
--control-switch-border-radius: 24px;
|
--switch-bar-border-radius: 24px;
|
||||||
--control-switch-padding: 6px;
|
--switch-bar-padding: 6px;
|
||||||
--mdc-icon-size: 24px;
|
--mdc-icon-size: 24px;
|
||||||
}
|
}
|
||||||
.vertical-switches {
|
.vertical-switches {
|
||||||
@@ -140,6 +140,6 @@ export class DemoHaControlSwitch extends LitElement {
|
|||||||
|
|
||||||
declare global {
|
declare global {
|
||||||
interface HTMLElementTagNameMap {
|
interface HTMLElementTagNameMap {
|
||||||
"demo-components-ha-control-switch": DemoHaControlSwitch;
|
"demo-components-ha-bar-switch": DemoHaBarSwitch;
|
||||||
}
|
}
|
||||||
}
|
}
|
@@ -1,3 +0,0 @@
|
|||||||
---
|
|
||||||
title: Control Button
|
|
||||||
---
|
|
@@ -1,192 +0,0 @@
|
|||||||
import {
|
|
||||||
mdiFanSpeed1,
|
|
||||||
mdiFanSpeed2,
|
|
||||||
mdiFanSpeed3,
|
|
||||||
mdiLightbulb,
|
|
||||||
} from "@mdi/js";
|
|
||||||
import { css, html, LitElement, TemplateResult } from "lit";
|
|
||||||
import { customElement } from "lit/decorators";
|
|
||||||
import { ifDefined } from "lit/directives/if-defined";
|
|
||||||
import { repeat } from "lit/directives/repeat";
|
|
||||||
import "../../../../src/components/ha-control-button";
|
|
||||||
import "../../../../src/components/ha-card";
|
|
||||||
import "../../../../src/components/ha-svg-icon";
|
|
||||||
import "../../../../src/components/ha-control-button-group";
|
|
||||||
|
|
||||||
type Button = {
|
|
||||||
label: string;
|
|
||||||
icon?: string;
|
|
||||||
class?: string;
|
|
||||||
disabled?: boolean;
|
|
||||||
};
|
|
||||||
|
|
||||||
const buttons: Button[] = [
|
|
||||||
{
|
|
||||||
label: "Button",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: "Button and custom style",
|
|
||||||
class: "custom",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: "Disabled Button",
|
|
||||||
disabled: true,
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
type ButtonGroup = {
|
|
||||||
vertical?: boolean;
|
|
||||||
class?: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
const buttonGroups: ButtonGroup[] = [
|
|
||||||
{},
|
|
||||||
{
|
|
||||||
class: "custom-group",
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
@customElement("demo-components-ha-control-button")
|
|
||||||
export class DemoHaBarButton extends LitElement {
|
|
||||||
protected render(): TemplateResult {
|
|
||||||
return html`
|
|
||||||
<ha-card>
|
|
||||||
${repeat(
|
|
||||||
buttons,
|
|
||||||
(btn) => html`
|
|
||||||
<div class="card-content">
|
|
||||||
<pre>Config: ${JSON.stringify(btn)}</pre>
|
|
||||||
<ha-control-button
|
|
||||||
class=${ifDefined(btn.class)}
|
|
||||||
label=${ifDefined(btn.label)}
|
|
||||||
disabled=${ifDefined(btn.disabled)}
|
|
||||||
>
|
|
||||||
<ha-svg-icon .path=${btn.icon || mdiLightbulb}></ha-svg-icon>
|
|
||||||
</ha-control-button>
|
|
||||||
</div>
|
|
||||||
`
|
|
||||||
)}
|
|
||||||
</ha-card>
|
|
||||||
|
|
||||||
<ha-card>
|
|
||||||
${repeat(
|
|
||||||
buttonGroups,
|
|
||||||
(group) => html`
|
|
||||||
<div class="card-content">
|
|
||||||
<pre>Config: ${JSON.stringify(group)}</pre>
|
|
||||||
<ha-control-button-group class=${ifDefined(group.class)}>
|
|
||||||
<ha-control-button>
|
|
||||||
<ha-svg-icon
|
|
||||||
.path=${mdiFanSpeed1}
|
|
||||||
label="Speed 1"
|
|
||||||
></ha-svg-icon>
|
|
||||||
</ha-control-button>
|
|
||||||
<ha-control-button>
|
|
||||||
<ha-svg-icon
|
|
||||||
.path=${mdiFanSpeed2}
|
|
||||||
label="Speed 2"
|
|
||||||
></ha-svg-icon>
|
|
||||||
</ha-control-button>
|
|
||||||
<ha-control-button>
|
|
||||||
<ha-svg-icon
|
|
||||||
.path=${mdiFanSpeed3}
|
|
||||||
label="Speed 3"
|
|
||||||
></ha-svg-icon>
|
|
||||||
</ha-control-button>
|
|
||||||
</ha-control-button-group>
|
|
||||||
</div>
|
|
||||||
`
|
|
||||||
)}
|
|
||||||
</ha-card>
|
|
||||||
<ha-card>
|
|
||||||
<div class="card-content">
|
|
||||||
<p class="title"><b>Vertical</b></p>
|
|
||||||
<div class="vertical-buttons">
|
|
||||||
${repeat(
|
|
||||||
buttonGroups,
|
|
||||||
(group) => html`
|
|
||||||
<ha-control-button-group
|
|
||||||
vertical
|
|
||||||
class=${ifDefined(group.class)}
|
|
||||||
>
|
|
||||||
<ha-control-button>
|
|
||||||
<ha-svg-icon
|
|
||||||
.path=${mdiFanSpeed1}
|
|
||||||
label="Speed 1"
|
|
||||||
></ha-svg-icon>
|
|
||||||
</ha-control-button>
|
|
||||||
<ha-control-button>
|
|
||||||
<ha-svg-icon
|
|
||||||
.path=${mdiFanSpeed2}
|
|
||||||
label="Speed 2"
|
|
||||||
></ha-svg-icon>
|
|
||||||
</ha-control-button>
|
|
||||||
<ha-control-button>
|
|
||||||
<ha-svg-icon
|
|
||||||
.path=${mdiFanSpeed3}
|
|
||||||
label="Speed 3"
|
|
||||||
></ha-svg-icon>
|
|
||||||
</ha-control-button>
|
|
||||||
</ha-control-button-group>
|
|
||||||
`
|
|
||||||
)}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</ha-card>
|
|
||||||
`;
|
|
||||||
}
|
|
||||||
|
|
||||||
static get styles() {
|
|
||||||
return css`
|
|
||||||
ha-card {
|
|
||||||
max-width: 600px;
|
|
||||||
margin: 24px auto;
|
|
||||||
}
|
|
||||||
pre {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 8px;
|
|
||||||
}
|
|
||||||
p {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
label {
|
|
||||||
font-weight: 600;
|
|
||||||
}
|
|
||||||
.custom {
|
|
||||||
--control-button-icon-color: var(--primary-color);
|
|
||||||
--control-button-background-color: var(--primary-color);
|
|
||||||
--control-button-background-opacity: 0.2;
|
|
||||||
--control-button-border-radius: 18px;
|
|
||||||
height: 100px;
|
|
||||||
width: 100px;
|
|
||||||
}
|
|
||||||
.custom-group {
|
|
||||||
--control-button-group-thickness: 100px;
|
|
||||||
--control-button-group-border-radius: 18px;
|
|
||||||
--control-button-group-spacing: 20px;
|
|
||||||
}
|
|
||||||
.custom-group ha-control-button {
|
|
||||||
--control-button-border-radius: 18px;
|
|
||||||
--mdc-icon-size: 32px;
|
|
||||||
}
|
|
||||||
.vertical-buttons {
|
|
||||||
height: 300px;
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
justify-content: space-between;
|
|
||||||
}
|
|
||||||
p.title {
|
|
||||||
margin-bottom: 12px;
|
|
||||||
}
|
|
||||||
.vertical-switches > *:not(:last-child) {
|
|
||||||
margin-right: 4px;
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
declare global {
|
|
||||||
interface HTMLElementTagNameMap {
|
|
||||||
"demo-components-ha-control-button": DemoHaBarButton;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,3 +0,0 @@
|
|||||||
---
|
|
||||||
title: Control Select
|
|
||||||
---
|
|
@@ -1,212 +0,0 @@
|
|||||||
import { mdiFanOff, mdiFanSpeed1, mdiFanSpeed2, mdiFanSpeed3 } from "@mdi/js";
|
|
||||||
import { css, html, LitElement, TemplateResult } from "lit";
|
|
||||||
import { customElement, state } from "lit/decorators";
|
|
||||||
import { ifDefined } from "lit/directives/if-defined";
|
|
||||||
import { repeat } from "lit/directives/repeat";
|
|
||||||
import "../../../../src/components/ha-card";
|
|
||||||
import "../../../../src/components/ha-control-select";
|
|
||||||
import type { ControlSelectOption } from "../../../../src/components/ha-control-select";
|
|
||||||
|
|
||||||
const fullOptions: ControlSelectOption[] = [
|
|
||||||
{
|
|
||||||
value: "off",
|
|
||||||
label: "Off",
|
|
||||||
path: mdiFanOff,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: "low",
|
|
||||||
label: "Low",
|
|
||||||
path: mdiFanSpeed1,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: "medium",
|
|
||||||
label: "Medium",
|
|
||||||
path: mdiFanSpeed2,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: "high",
|
|
||||||
label: "High",
|
|
||||||
path: mdiFanSpeed3,
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
const iconOptions: ControlSelectOption[] = [
|
|
||||||
{
|
|
||||||
value: "off",
|
|
||||||
path: mdiFanOff,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: "low",
|
|
||||||
path: mdiFanSpeed1,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: "medium",
|
|
||||||
path: mdiFanSpeed2,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: "high",
|
|
||||||
path: mdiFanSpeed3,
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
const labelOptions: ControlSelectOption[] = [
|
|
||||||
{
|
|
||||||
value: "off",
|
|
||||||
label: "Off",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: "low",
|
|
||||||
label: "Low",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: "medium",
|
|
||||||
label: "Medium",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: "high",
|
|
||||||
label: "High",
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
const selects: {
|
|
||||||
id: string;
|
|
||||||
label: string;
|
|
||||||
class?: string;
|
|
||||||
options: ControlSelectOption[];
|
|
||||||
disabled?: boolean;
|
|
||||||
}[] = [
|
|
||||||
{
|
|
||||||
id: "label",
|
|
||||||
label: "Select with labels",
|
|
||||||
options: labelOptions,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: "icon",
|
|
||||||
label: "Select with icons",
|
|
||||||
options: iconOptions,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: "icon",
|
|
||||||
label: "Disabled select",
|
|
||||||
options: iconOptions,
|
|
||||||
disabled: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: "custom",
|
|
||||||
label: "Select and custom style",
|
|
||||||
class: "custom",
|
|
||||||
options: fullOptions,
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
@customElement("demo-components-ha-control-select")
|
|
||||||
export class DemoHaControlSelect extends LitElement {
|
|
||||||
@state() private value?: string = "off";
|
|
||||||
|
|
||||||
handleValueChanged(e: CustomEvent) {
|
|
||||||
this.value = e.detail.value as string;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected render(): TemplateResult {
|
|
||||||
return html`
|
|
||||||
<ha-card>
|
|
||||||
<div class="card-content">
|
|
||||||
<p><b>Slider values</b></p>
|
|
||||||
<table>
|
|
||||||
<tbody>
|
|
||||||
<tr>
|
|
||||||
<td>value</td>
|
|
||||||
<td>${this.value ?? "-"}</td>
|
|
||||||
</tr>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
</ha-card>
|
|
||||||
${repeat(selects, (select) => {
|
|
||||||
const { id, label, options, ...config } = select;
|
|
||||||
return html`
|
|
||||||
<ha-card>
|
|
||||||
<div class="card-content">
|
|
||||||
<label id=${id}>${label}</label>
|
|
||||||
<pre>Config: ${JSON.stringify(config)}</pre>
|
|
||||||
<ha-control-select
|
|
||||||
.value=${this.value}
|
|
||||||
.options=${options}
|
|
||||||
class=${ifDefined(config.class)}
|
|
||||||
@value-changed=${this.handleValueChanged}
|
|
||||||
aria-labelledby=${id}
|
|
||||||
disabled=${ifDefined(config.disabled)}
|
|
||||||
>
|
|
||||||
</ha-control-select>
|
|
||||||
</div>
|
|
||||||
</ha-card>
|
|
||||||
`;
|
|
||||||
})}
|
|
||||||
<ha-card>
|
|
||||||
<div class="card-content">
|
|
||||||
<p class="title"><b>Vertical</b></p>
|
|
||||||
<div class="vertical-selects">
|
|
||||||
${repeat(selects, (select) => {
|
|
||||||
const { id, label, options, ...config } = select;
|
|
||||||
return html`
|
|
||||||
<ha-control-select
|
|
||||||
.value=${this.value}
|
|
||||||
.options=${options}
|
|
||||||
vertical
|
|
||||||
class=${ifDefined(config.class)}
|
|
||||||
@value-changed=${this.handleValueChanged}
|
|
||||||
aria-labelledby=${id}
|
|
||||||
disabled=${ifDefined(config.disabled)}
|
|
||||||
>
|
|
||||||
</ha-control-select>
|
|
||||||
`;
|
|
||||||
})}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</ha-card>
|
|
||||||
`;
|
|
||||||
}
|
|
||||||
|
|
||||||
static get styles() {
|
|
||||||
return css`
|
|
||||||
ha-card {
|
|
||||||
max-width: 600px;
|
|
||||||
margin: 24px auto;
|
|
||||||
}
|
|
||||||
pre {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 8px;
|
|
||||||
}
|
|
||||||
p {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
label {
|
|
||||||
font-weight: 600;
|
|
||||||
}
|
|
||||||
.custom {
|
|
||||||
--mdc-icon-size: 24px;
|
|
||||||
--control-select-color: var(--state-fan-active-color);
|
|
||||||
--control-select-thickness: 100px;
|
|
||||||
--control-select-border-radius: 24px;
|
|
||||||
}
|
|
||||||
.vertical-selects {
|
|
||||||
height: 300px;
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
justify-content: space-between;
|
|
||||||
}
|
|
||||||
p.title {
|
|
||||||
margin-bottom: 12px;
|
|
||||||
}
|
|
||||||
.vertical-selects > *:not(:last-child) {
|
|
||||||
margin-right: 4px;
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
declare global {
|
|
||||||
interface HTMLElementTagNameMap {
|
|
||||||
"demo-components-ha-control-select": DemoHaControlSelect;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,3 +0,0 @@
|
|||||||
---
|
|
||||||
title: Control Slider
|
|
||||||
---
|
|
@@ -1,3 +0,0 @@
|
|||||||
---
|
|
||||||
title: Control Switch
|
|
||||||
---
|
|
@@ -99,19 +99,16 @@ const AREAS = [
|
|||||||
area_id: "backyard",
|
area_id: "backyard",
|
||||||
name: "Backyard",
|
name: "Backyard",
|
||||||
picture: null,
|
picture: null,
|
||||||
aliases: [],
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
area_id: "bedroom",
|
area_id: "bedroom",
|
||||||
name: "Bedroom",
|
name: "Bedroom",
|
||||||
picture: null,
|
picture: null,
|
||||||
aliases: [],
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
area_id: "livingroom",
|
area_id: "livingroom",
|
||||||
name: "Livingroom",
|
name: "Livingroom",
|
||||||
picture: null,
|
picture: null,
|
||||||
aliases: [],
|
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@@ -95,19 +95,16 @@ const AREAS = [
|
|||||||
area_id: "backyard",
|
area_id: "backyard",
|
||||||
name: "Backyard",
|
name: "Backyard",
|
||||||
picture: null,
|
picture: null,
|
||||||
aliases: [],
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
area_id: "bedroom",
|
area_id: "bedroom",
|
||||||
name: "Bedroom",
|
name: "Bedroom",
|
||||||
picture: null,
|
picture: null,
|
||||||
aliases: [],
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
area_id: "livingroom",
|
area_id: "livingroom",
|
||||||
name: "Livingroom",
|
name: "Livingroom",
|
||||||
picture: null,
|
picture: null,
|
||||||
aliases: [],
|
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@@ -3,7 +3,6 @@ import { customElement } from "lit/decorators";
|
|||||||
import "../../../../src/components/ha-tip";
|
import "../../../../src/components/ha-tip";
|
||||||
import "../../../../src/components/ha-card";
|
import "../../../../src/components/ha-card";
|
||||||
import { applyThemesOnElement } from "../../../../src/common/dom/apply_themes_on_element";
|
import { applyThemesOnElement } from "../../../../src/common/dom/apply_themes_on_element";
|
||||||
import { provideHass } from "../../../../src/fake_data/provide_hass";
|
|
||||||
|
|
||||||
const tips: (string | TemplateResult)[] = [
|
const tips: (string | TemplateResult)[] = [
|
||||||
"Test tip",
|
"Test tip",
|
||||||
@@ -19,11 +18,7 @@ export class DemoHaTip extends LitElement {
|
|||||||
<div class=${mode}>
|
<div class=${mode}>
|
||||||
<ha-card header="ha-tip ${mode} demo">
|
<ha-card header="ha-tip ${mode} demo">
|
||||||
<div class="card-content">
|
<div class="card-content">
|
||||||
${tips.map(
|
${tips.map((tip) => html`<ha-tip>${tip}</ha-tip>`)}
|
||||||
(tip) => html`<ha-tip .hass=${provideHass(this)}
|
|
||||||
>${tip}</ha-tip
|
|
||||||
>`
|
|
||||||
)}
|
|
||||||
</div>
|
</div>
|
||||||
</ha-card>
|
</ha-card>
|
||||||
</div>
|
</div>
|
||||||
|
@@ -1,3 +0,0 @@
|
|||||||
---
|
|
||||||
title: Tile Card
|
|
||||||
---
|
|
@@ -1,173 +0,0 @@
|
|||||||
import { html, LitElement, PropertyValues, TemplateResult } from "lit";
|
|
||||||
import { customElement, query } from "lit/decorators";
|
|
||||||
import { CoverEntityFeature } from "../../../../src/data/cover";
|
|
||||||
import { LightColorMode } from "../../../../src/data/light";
|
|
||||||
import { VacuumEntityFeature } from "../../../../src/data/vacuum";
|
|
||||||
import { getEntity } from "../../../../src/fake_data/entity";
|
|
||||||
import { provideHass } from "../../../../src/fake_data/provide_hass";
|
|
||||||
import "../../components/demo-cards";
|
|
||||||
|
|
||||||
const ENTITIES = [
|
|
||||||
getEntity("switch", "tv_outlet", "on", {
|
|
||||||
friendly_name: "TV outlet",
|
|
||||||
device_class: "outlet",
|
|
||||||
}),
|
|
||||||
getEntity("light", "bed_light", "on", {
|
|
||||||
friendly_name: "Bed Light",
|
|
||||||
supported_color_modes: [LightColorMode.HS],
|
|
||||||
}),
|
|
||||||
getEntity("light", "unavailable", "unavailable", {
|
|
||||||
friendly_name: "Unavailable entity",
|
|
||||||
}),
|
|
||||||
getEntity("climate", "thermostat", "heat", {
|
|
||||||
current_temperature: 73,
|
|
||||||
min_temp: 45,
|
|
||||||
max_temp: 95,
|
|
||||||
temperature: 80,
|
|
||||||
hvac_modes: ["heat", "cool", "auto", "off"],
|
|
||||||
friendly_name: "Thermostat",
|
|
||||||
hvac_action: "heating",
|
|
||||||
}),
|
|
||||||
getEntity("person", "paulus", "home", {
|
|
||||||
friendly_name: "Paulus",
|
|
||||||
}),
|
|
||||||
getEntity("vacuum", "first_floor_vacuum", "docked", {
|
|
||||||
friendly_name: "First floor vacuum",
|
|
||||||
supported_features:
|
|
||||||
VacuumEntityFeature.START +
|
|
||||||
VacuumEntityFeature.STOP +
|
|
||||||
VacuumEntityFeature.RETURN_HOME,
|
|
||||||
}),
|
|
||||||
getEntity("cover", "kitchen_shutter", "open", {
|
|
||||||
friendly_name: "Kitchen shutter",
|
|
||||||
device_class: "shutter",
|
|
||||||
supported_features:
|
|
||||||
CoverEntityFeature.CLOSE +
|
|
||||||
CoverEntityFeature.OPEN +
|
|
||||||
CoverEntityFeature.STOP,
|
|
||||||
}),
|
|
||||||
getEntity("cover", "pergola_roof", "open", {
|
|
||||||
friendly_name: "Pergola Roof",
|
|
||||||
supported_features:
|
|
||||||
CoverEntityFeature.CLOSE_TILT +
|
|
||||||
CoverEntityFeature.OPEN_TILT +
|
|
||||||
CoverEntityFeature.STOP_TILT,
|
|
||||||
}),
|
|
||||||
];
|
|
||||||
|
|
||||||
const CONFIGS = [
|
|
||||||
{
|
|
||||||
heading: "Basic example",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: switch.tv_outlet
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Vertical example",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: switch.tv_outlet
|
|
||||||
vertical: true
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Custom color",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: switch.tv_outlet
|
|
||||||
color: pink
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Unknown entity",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: light.unknown
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Unavailable entity",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: light.unavailable
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Climate",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: climate.thermostat
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Person",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: person.paulus
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Light brightness feature",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: light.bed_light
|
|
||||||
features:
|
|
||||||
- type: "light-brightness"
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Vacuum commands feature",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: vacuum.first_floor_vacuum
|
|
||||||
features:
|
|
||||||
- type: "vacuum-commands"
|
|
||||||
commands:
|
|
||||||
- start_pause
|
|
||||||
- stop
|
|
||||||
- return_home
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Cover open close feature",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: cover.kitchen_shutter
|
|
||||||
features:
|
|
||||||
- type: "cover-open-close"
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
heading: "Cover tilt feature",
|
|
||||||
config: `
|
|
||||||
- type: tile
|
|
||||||
entity: cover.pergola_roof
|
|
||||||
features:
|
|
||||||
- type: "cover-tilt"
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
@customElement("demo-lovelace-tile-card")
|
|
||||||
class DemoTile extends LitElement {
|
|
||||||
@query("#demos") private _demoRoot!: HTMLElement;
|
|
||||||
|
|
||||||
protected render(): TemplateResult {
|
|
||||||
return html`<demo-cards id="demos" .configs=${CONFIGS}></demo-cards>`;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected firstUpdated(changedProperties: PropertyValues) {
|
|
||||||
super.firstUpdated(changedProperties);
|
|
||||||
const hass = provideHass(this._demoRoot);
|
|
||||||
hass.updateTranslations(null, "en");
|
|
||||||
hass.updateTranslations("lovelace", "en");
|
|
||||||
hass.addEntities(ENTITIES);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
declare global {
|
|
||||||
interface HTMLElementTagNameMap {
|
|
||||||
"demo-lovelace-tile-card": DemoTile;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -2,7 +2,7 @@ import {
|
|||||||
HassEntity,
|
HassEntity,
|
||||||
HassEntityAttributeBase,
|
HassEntityAttributeBase,
|
||||||
} from "home-assistant-js-websocket";
|
} from "home-assistant-js-websocket";
|
||||||
import { css, html, LitElement, nothing } from "lit";
|
import { css, html, LitElement, TemplateResult } from "lit";
|
||||||
import { customElement, property } from "lit/decorators";
|
import { customElement, property } from "lit/decorators";
|
||||||
import memoizeOne from "memoize-one";
|
import memoizeOne from "memoize-one";
|
||||||
import { computeDomain } from "../../../../src/common/entity/compute_domain";
|
import { computeDomain } from "../../../../src/common/entity/compute_domain";
|
||||||
@@ -104,17 +104,16 @@ const ENTITIES: HassEntity[] = [
|
|||||||
createEntity("alarm_control_panel.disarming", "disarming"),
|
createEntity("alarm_control_panel.disarming", "disarming"),
|
||||||
createEntity("alarm_control_panel.triggered", "triggered"),
|
createEntity("alarm_control_panel.triggered", "triggered"),
|
||||||
// Alert
|
// Alert
|
||||||
createEntity("alert.idle", "idle"),
|
|
||||||
createEntity("alert.off", "off"),
|
createEntity("alert.off", "off"),
|
||||||
createEntity("alert.on", "on"),
|
createEntity("alert.on", "on"),
|
||||||
|
createEntity("alert.idle", "idle"),
|
||||||
// Automation
|
// Automation
|
||||||
createEntity("automation.off", "off"),
|
createEntity("automation.off", "off"),
|
||||||
createEntity("automation.on", "on"),
|
createEntity("automation.on", "on"),
|
||||||
// Binary Sensor
|
// Binary Sensor
|
||||||
...BINARY_SENSOR_DEVICE_CLASSES.map((dc) => [
|
...BINARY_SENSOR_DEVICE_CLASSES.map((dc) =>
|
||||||
createEntity(`binary_sensor.${dc}`, "off", dc),
|
createEntity(`binary_sensor.${dc}`, "on", dc)
|
||||||
createEntity(`binary_sensor.${dc}`, "on", dc),
|
),
|
||||||
]).reduce((arr, item) => [...arr, ...item], []),
|
|
||||||
// Button
|
// Button
|
||||||
createEntity("button.restart", "unknown", "restart"),
|
createEntity("button.restart", "unknown", "restart"),
|
||||||
createEntity("button.update", "unknown", "update"),
|
createEntity("button.update", "unknown", "update"),
|
||||||
@@ -143,9 +142,6 @@ const ENTITIES: HassEntity[] = [
|
|||||||
createEntity("climate.auto_dry", "auto", undefined, {
|
createEntity("climate.auto_dry", "auto", undefined, {
|
||||||
hvac_action: "drying",
|
hvac_action: "drying",
|
||||||
}),
|
}),
|
||||||
createEntity("climate.auto_fan", "auto", undefined, {
|
|
||||||
hvac_action: "fan",
|
|
||||||
}),
|
|
||||||
// Cover
|
// Cover
|
||||||
createEntity("cover.closing", "closing"),
|
createEntity("cover.closing", "closing"),
|
||||||
createEntity("cover.closed", "closed"),
|
createEntity("cover.closed", "closed"),
|
||||||
@@ -184,8 +180,8 @@ const ENTITIES: HassEntity[] = [
|
|||||||
createEntity("light.off", "off"),
|
createEntity("light.off", "off"),
|
||||||
createEntity("light.on", "on"),
|
createEntity("light.on", "on"),
|
||||||
// Locks
|
// Locks
|
||||||
createEntity("lock.locked", "locked"),
|
|
||||||
createEntity("lock.unlocked", "unlocked"),
|
createEntity("lock.unlocked", "unlocked"),
|
||||||
|
createEntity("lock.locked", "locked"),
|
||||||
createEntity("lock.locking", "locking"),
|
createEntity("lock.locking", "locking"),
|
||||||
createEntity("lock.unlocking", "unlocking"),
|
createEntity("lock.unlocking", "unlocking"),
|
||||||
createEntity("lock.jammed", "jammed"),
|
createEntity("lock.jammed", "jammed"),
|
||||||
@@ -209,24 +205,17 @@ const ENTITIES: HassEntity[] = [
|
|||||||
createEntity("media_player.speaker_playing", "playing", "speaker"),
|
createEntity("media_player.speaker_playing", "playing", "speaker"),
|
||||||
createEntity("media_player.speaker_paused", "paused", "speaker"),
|
createEntity("media_player.speaker_paused", "paused", "speaker"),
|
||||||
createEntity("media_player.speaker_standby", "standby", "speaker"),
|
createEntity("media_player.speaker_standby", "standby", "speaker"),
|
||||||
// Plant
|
|
||||||
createEntity("plant.ok", "ok"),
|
|
||||||
createEntity("plant.problem", "problem"),
|
|
||||||
// Remote
|
// Remote
|
||||||
createEntity("remote.off", "off"),
|
createEntity("remote.off", "off"),
|
||||||
createEntity("remote.on", "on"),
|
createEntity("remote.on", "on"),
|
||||||
// Schedule
|
|
||||||
createEntity("schedule.off", "off"),
|
|
||||||
createEntity("schedule.on", "on"),
|
|
||||||
// Script
|
// Script
|
||||||
createEntity("script.off", "off"),
|
createEntity("script.off", "off"),
|
||||||
createEntity("script.on", "on"),
|
createEntity("script.on", "on"),
|
||||||
// Sensor
|
// Sensor
|
||||||
...SENSOR_DEVICE_CLASSES.map((dc) => createEntity(`sensor.${dc}`, "10", dc)),
|
...SENSOR_DEVICE_CLASSES.map((dc) => createEntity(`sensor.${dc}`, "10", dc)),
|
||||||
// Battery sensor
|
// Battery sensor
|
||||||
...[0, 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, "unknown", "not_valid"].map(
|
...[0, 10, 20, 30, 40, 50, 60, 70, 80, 90, 100].map((value) =>
|
||||||
(value) =>
|
createEntity(`sensor.battery_${value}`, value.toString(), "battery")
|
||||||
createEntity(`sensor.battery_${value}`, value.toString(), "battery")
|
|
||||||
),
|
),
|
||||||
// Siren
|
// Siren
|
||||||
createEntity("siren.off", "off"),
|
createEntity("siren.off", "off"),
|
||||||
@@ -387,9 +376,9 @@ export class DemoEntityState extends LitElement {
|
|||||||
hass.updateTranslations("config", "en");
|
hass.updateTranslations("config", "en");
|
||||||
}
|
}
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (!this.hass) {
|
if (!this.hass) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
|
|
||||||
return html`
|
return html`
|
||||||
|
@@ -1,22 +1,22 @@
|
|||||||
import { css, html, LitElement, nothing } from "lit";
|
import { html, css, LitElement, TemplateResult } from "lit";
|
||||||
import "../../../../src/components/ha-formfield";
|
import "../../../../src/components/ha-formfield";
|
||||||
import "../../../../src/components/ha-switch";
|
import "../../../../src/components/ha-switch";
|
||||||
|
|
||||||
import { customElement, property, state } from "lit/decorators";
|
|
||||||
import { classMap } from "lit/directives/class-map";
|
import { classMap } from "lit/directives/class-map";
|
||||||
|
import { customElement, property, state } from "lit/decorators";
|
||||||
import { IntegrationManifest } from "../../../../src/data/integration";
|
import { IntegrationManifest } from "../../../../src/data/integration";
|
||||||
|
|
||||||
import { DeviceRegistryEntry } from "../../../../src/data/device_registry";
|
|
||||||
import { EntityRegistryEntry } from "../../../../src/data/entity_registry";
|
|
||||||
import { provideHass } from "../../../../src/fake_data/provide_hass";
|
import { provideHass } from "../../../../src/fake_data/provide_hass";
|
||||||
|
import { HomeAssistant } from "../../../../src/types";
|
||||||
|
import "../../../../src/panels/config/integrations/ha-integration-card";
|
||||||
|
import "../../../../src/panels/config/integrations/ha-ignored-config-entry-card";
|
||||||
import "../../../../src/panels/config/integrations/ha-config-flow-card";
|
import "../../../../src/panels/config/integrations/ha-config-flow-card";
|
||||||
import type {
|
import type {
|
||||||
ConfigEntryExtended,
|
ConfigEntryExtended,
|
||||||
DataEntryFlowProgressExtended,
|
DataEntryFlowProgressExtended,
|
||||||
} from "../../../../src/panels/config/integrations/ha-config-integrations";
|
} from "../../../../src/panels/config/integrations/ha-config-integrations";
|
||||||
import "../../../../src/panels/config/integrations/ha-ignored-config-entry-card";
|
import { DeviceRegistryEntry } from "../../../../src/data/device_registry";
|
||||||
import "../../../../src/panels/config/integrations/ha-integration-card";
|
import { EntityRegistryEntry } from "../../../../src/data/entity_registry";
|
||||||
import { HomeAssistant } from "../../../../src/types";
|
|
||||||
|
|
||||||
const createConfigEntry = (
|
const createConfigEntry = (
|
||||||
title: string,
|
title: string,
|
||||||
@@ -197,7 +197,6 @@ const createEntityRegistryEntries = (
|
|||||||
platform: "updater",
|
platform: "updater",
|
||||||
has_entity_name: false,
|
has_entity_name: false,
|
||||||
unique_id: "updater",
|
unique_id: "updater",
|
||||||
options: null,
|
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -231,9 +230,9 @@ export class DemoIntegrationCard extends LitElement {
|
|||||||
|
|
||||||
@state() isCloud = false;
|
@state() isCloud = false;
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (!this.hass) {
|
if (!this.hass) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
return html`
|
return html`
|
||||||
<div class="container">
|
<div class="container">
|
||||||
|
@@ -1,8 +1,8 @@
|
|||||||
import webpack from "../build-scripts/webpack.cjs";
|
const { createGalleryConfig } = require("../build-scripts/webpack.js");
|
||||||
import env from "../build-scripts/env.cjs";
|
const { isProdBuild, isStatsBuild } = require("../build-scripts/env.js");
|
||||||
|
|
||||||
export default webpack.createGalleryConfig({
|
module.exports = createGalleryConfig({
|
||||||
isProdBuild: env.isProdBuild(),
|
isProdBuild: isProdBuild(),
|
||||||
isStatsBuild: env.isStatsBuild(),
|
isStatsBuild: isStatsBuild(),
|
||||||
latestBuild: true,
|
latestBuild: true,
|
||||||
});
|
});
|
||||||
|
14
gulpfile.js
14
gulpfile.js
@@ -1,13 +1,3 @@
|
|||||||
import { globIterate } from "glob";
|
var requireDir = require("require-dir");
|
||||||
|
|
||||||
const gulpImports = [];
|
requireDir("./build-scripts/gulp/");
|
||||||
|
|
||||||
for await (const gulpModule of globIterate("build-scripts/gulp/*.?(c|m)js", {
|
|
||||||
dotRelative: true,
|
|
||||||
})) {
|
|
||||||
gulpImports.push(import(gulpModule));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Since all tasks are currently registered with gulp.task(), this is enough
|
|
||||||
// If any are converted to named exports, need to loop and aggregate exports here
|
|
||||||
await Promise.all(gulpImports);
|
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
import rollup from "../build-scripts/rollup.cjs";
|
const rollup = require("../build-scripts/rollup.js");
|
||||||
import env from "../build-scripts/env.cjs";
|
const env = require("../build-scripts/env.js");
|
||||||
|
|
||||||
const config = rollup.createHassioConfig({
|
const config = rollup.createHassioConfig({
|
||||||
isProdBuild: env.isProdBuild(),
|
isProdBuild: env.isProdBuild(),
|
||||||
@@ -7,4 +7,4 @@ const config = rollup.createHassioConfig({
|
|||||||
isStatsBuild: env.isStatsBuild(),
|
isStatsBuild: env.isStatsBuild(),
|
||||||
});
|
});
|
||||||
|
|
||||||
export default { ...config.inputOptions, output: config.outputOptions };
|
module.exports = { ...config.inputOptions, output: config.outputOptions };
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
import { mdiArrowUpBoldCircle, mdiPuzzle } from "@mdi/js";
|
import { mdiArrowUpBoldCircle, mdiPuzzle } from "@mdi/js";
|
||||||
import { css, CSSResultGroup, html, LitElement, TemplateResult } from "lit";
|
import { css, CSSResultGroup, html, LitElement, TemplateResult } from "lit";
|
||||||
import { customElement, property } from "lit/decorators";
|
import { property } from "lit/decorators";
|
||||||
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";
|
||||||
@@ -14,8 +14,7 @@ import "../components/hassio-card-content";
|
|||||||
import { filterAndSort } from "../components/hassio-filter-addons";
|
import { filterAndSort } from "../components/hassio-filter-addons";
|
||||||
import { hassioStyle } from "../resources/hassio-style";
|
import { hassioStyle } from "../resources/hassio-style";
|
||||||
|
|
||||||
@customElement("hassio-addon-repository")
|
class HassioAddonRepositoryEl extends LitElement {
|
||||||
export class HassioAddonRepositoryEl extends LitElement {
|
|
||||||
@property({ attribute: false }) public hass!: HomeAssistant;
|
@property({ attribute: false }) public hass!: HomeAssistant;
|
||||||
|
|
||||||
@property({ attribute: false }) public supervisor!: Supervisor;
|
@property({ attribute: false }) public supervisor!: Supervisor;
|
||||||
@@ -141,3 +140,5 @@ export class HassioAddonRepositoryEl extends LitElement {
|
|||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
customElements.define("hassio-addon-repository", HassioAddonRepositoryEl);
|
||||||
|
@@ -6,11 +6,10 @@ import {
|
|||||||
CSSResultGroup,
|
CSSResultGroup,
|
||||||
html,
|
html,
|
||||||
LitElement,
|
LitElement,
|
||||||
nothing,
|
|
||||||
PropertyValues,
|
PropertyValues,
|
||||||
TemplateResult,
|
TemplateResult,
|
||||||
} from "lit";
|
} from "lit";
|
||||||
import { customElement, property, state } from "lit/decorators";
|
import { property, state } from "lit/decorators";
|
||||||
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 { fireEvent } from "../../../src/common/dom/fire_event";
|
import { fireEvent } from "../../../src/common/dom/fire_event";
|
||||||
@@ -50,8 +49,7 @@ const sortRepos = (a: HassioAddonRepository, b: HassioAddonRepository) => {
|
|||||||
return a.name.toUpperCase() < b.name.toUpperCase() ? -1 : 1;
|
return a.name.toUpperCase() < b.name.toUpperCase() ? -1 : 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
@customElement("hassio-addon-store")
|
class HassioAddonStore extends LitElement {
|
||||||
export class HassioAddonStore extends LitElement {
|
|
||||||
@property({ attribute: false }) public hass!: HomeAssistant;
|
@property({ attribute: false }) public hass!: HomeAssistant;
|
||||||
|
|
||||||
@property({ attribute: false }) public supervisor!: Supervisor;
|
@property({ attribute: false }) public supervisor!: Supervisor;
|
||||||
@@ -74,8 +72,8 @@ export class HassioAddonStore extends LitElement {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
let repos: (TemplateResult | typeof nothing)[] = [];
|
let repos: TemplateResult[] = [];
|
||||||
|
|
||||||
if (this.supervisor.store.repositories) {
|
if (this.supervisor.store.repositories) {
|
||||||
repos = this.addonRepositories(
|
repos = this.addonRepositories(
|
||||||
@@ -92,7 +90,11 @@ export class HassioAddonStore extends LitElement {
|
|||||||
.route=${this.route}
|
.route=${this.route}
|
||||||
.header=${this.supervisor.localize("panel.store")}
|
.header=${this.supervisor.localize("panel.store")}
|
||||||
>
|
>
|
||||||
<ha-button-menu slot="toolbar-icon" @action=${this._handleAction}>
|
<ha-button-menu
|
||||||
|
corner="BOTTOM_START"
|
||||||
|
slot="toolbar-icon"
|
||||||
|
@action=${this._handleAction}
|
||||||
|
>
|
||||||
<ha-icon-button
|
<ha-icon-button
|
||||||
.label=${this.supervisor.localize("common.menu")}
|
.label=${this.supervisor.localize("common.menu")}
|
||||||
.path=${mdiDotsVertical}
|
.path=${mdiDotsVertical}
|
||||||
@@ -170,7 +172,7 @@ export class HassioAddonStore extends LitElement {
|
|||||||
.supervisor=${this.supervisor}
|
.supervisor=${this.supervisor}
|
||||||
></hassio-addon-repository>
|
></hassio-addon-repository>
|
||||||
`
|
`
|
||||||
: nothing;
|
: html``;
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -216,7 +218,7 @@ export class HassioAddonStore extends LitElement {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private _filterChanged(e) {
|
private async _filterChanged(e) {
|
||||||
this._filter = e.detail.value;
|
this._filter = e.detail.value;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -248,3 +250,5 @@ export class HassioAddonStore extends LitElement {
|
|||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
customElements.define("hassio-addon-store", HassioAddonStore);
|
||||||
|
@@ -114,6 +114,9 @@ class HassioAddonAudio extends LitElement {
|
|||||||
ha-card {
|
ha-card {
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
|
paper-item {
|
||||||
|
width: 450px;
|
||||||
|
}
|
||||||
.card-actions {
|
.card-actions {
|
||||||
text-align: right;
|
text-align: right;
|
||||||
}
|
}
|
||||||
|
@@ -168,7 +168,7 @@ class HassioAddonConfig extends LitElement {
|
|||||||
${this.supervisor.localize("addon.configuration.options.header")}
|
${this.supervisor.localize("addon.configuration.options.header")}
|
||||||
</h2>
|
</h2>
|
||||||
<div class="card-menu">
|
<div class="card-menu">
|
||||||
<ha-button-menu @action=${this._handleAction}>
|
<ha-button-menu corner="BOTTOM_START" @action=${this._handleAction}>
|
||||||
<ha-icon-button
|
<ha-icon-button
|
||||||
.label=${this.supervisor.localize("common.menu")}
|
.label=${this.supervisor.localize("common.menu")}
|
||||||
.path=${mdiDotsVertical}
|
.path=${mdiDotsVertical}
|
||||||
|
@@ -4,7 +4,7 @@ import {
|
|||||||
html,
|
html,
|
||||||
LitElement,
|
LitElement,
|
||||||
PropertyValues,
|
PropertyValues,
|
||||||
nothing,
|
TemplateResult,
|
||||||
} from "lit";
|
} from "lit";
|
||||||
import { customElement, property, state } from "lit/decorators";
|
import { customElement, property, state } from "lit/decorators";
|
||||||
import memoizeOne from "memoize-one";
|
import memoizeOne from "memoize-one";
|
||||||
@@ -47,9 +47,9 @@ class HassioAddonNetwork extends LitElement {
|
|||||||
this._setNetworkConfig();
|
this._setNetworkConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected render() {
|
protected render(): TemplateResult {
|
||||||
if (!this._config) {
|
if (!this._config) {
|
||||||
return nothing;
|
return html``;
|
||||||
}
|
}
|
||||||
|
|
||||||
const hasHiddenOptions = Object.keys(this._config).find(
|
const hasHiddenOptions = Object.keys(this._config).find(
|
||||||
|
@@ -29,6 +29,7 @@ import memoizeOne from "memoize-one";
|
|||||||
import { atLeastVersion } from "../../../../src/common/config/version";
|
import { atLeastVersion } from "../../../../src/common/config/version";
|
||||||
import { fireEvent } from "../../../../src/common/dom/fire_event";
|
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-progress-button";
|
import "../../../../src/components/buttons/ha-progress-button";
|
||||||
import "../../../../src/components/ha-alert";
|
import "../../../../src/components/ha-alert";
|
||||||
import "../../../../src/components/ha-card";
|
import "../../../../src/components/ha-card";
|
||||||
@@ -46,7 +47,6 @@ import {
|
|||||||
HassioAddonSetOptionParams,
|
HassioAddonSetOptionParams,
|
||||||
HassioAddonSetSecurityParams,
|
HassioAddonSetSecurityParams,
|
||||||
installHassioAddon,
|
installHassioAddon,
|
||||||
rebuildLocalAddon,
|
|
||||||
restartHassioAddon,
|
restartHassioAddon,
|
||||||
setHassioAddonOption,
|
setHassioAddonOption,
|
||||||
setHassioAddonSecurity,
|
setHassioAddonSecurity,
|
||||||
@@ -640,12 +640,13 @@ class HassioAddonInfo extends LitElement {
|
|||||||
</ha-progress-button>
|
</ha-progress-button>
|
||||||
${this.addon.build
|
${this.addon.build
|
||||||
? html`
|
? html`
|
||||||
<ha-progress-button
|
<ha-call-api-button
|
||||||
class="warning"
|
class="warning"
|
||||||
@click=${this._rebuildClicked}
|
.hass=${this.hass}
|
||||||
|
.path="hassio/addons/${this.addon.slug}/rebuild"
|
||||||
>
|
>
|
||||||
${this.supervisor.localize("addon.dashboard.rebuild")}
|
${this.supervisor.localize("addon.dashboard.rebuild")}
|
||||||
</ha-progress-button>
|
</ha-call-api-button>
|
||||||
`
|
`
|
||||||
: ""}`
|
: ""}`
|
||||||
: ""}
|
: ""}
|
||||||
@@ -965,21 +966,6 @@ class HassioAddonInfo extends LitElement {
|
|||||||
button.progress = false;
|
button.progress = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private async _rebuildClicked(ev: CustomEvent): Promise<void> {
|
|
||||||
const button = ev.currentTarget as any;
|
|
||||||
button.progress = true;
|
|
||||||
|
|
||||||
try {
|
|
||||||
await rebuildLocalAddon(this.hass, this.addon.slug);
|
|
||||||
} catch (err: any) {
|
|
||||||
showAlertDialog(this, {
|
|
||||||
title: this.supervisor.localize("addon.dashboard.action_error.rebuild"),
|
|
||||||
text: extractApiErrorMessage(err),
|
|
||||||
});
|
|
||||||
}
|
|
||||||
button.progress = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private async _startClicked(ev: CustomEvent): Promise<void> {
|
private async _startClicked(ev: CustomEvent): Promise<void> {
|
||||||
const button = ev.currentTarget as any;
|
const button = ev.currentTarget as any;
|
||||||
button.progress = true;
|
button.progress = true;
|
||||||
@@ -1138,6 +1124,10 @@ class HassioAddonInfo extends LitElement {
|
|||||||
ha-svg-icon.stopped {
|
ha-svg-icon.stopped {
|
||||||
color: var(--error-color);
|
color: var(--error-color);
|
||||||
}
|
}
|
||||||
|
ha-call-api-button {
|
||||||
|
font-weight: 500;
|
||||||
|
color: var(--primary-color);
|
||||||
|
}
|
||||||
protection-enable mwc-button {
|
protection-enable mwc-button {
|
||||||
--mdc-theme-primary: white;
|
--mdc-theme-primary: white;
|
||||||
}
|
}
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user