diff --git a/.gitignore b/.gitignore
index 743889ba4e..8b568f884c 100644
--- a/.gitignore
+++ b/.gitignore
@@ -25,6 +25,9 @@ dist
.vscode/*
!.vscode/extensions.json
+# Cast dev settings
+src/cast/dev_const.ts
+
# Secrets
.lokalise_token
yarn-error.log
diff --git a/cast/README.md b/cast/README.md
index aaf3141759..c1741fc989 100644
--- a/cast/README.md
+++ b/cast/README.md
@@ -25,7 +25,7 @@ Home Assistant Cast is made up of two separate applications:
### Setting dev variables
-Open `src/cast/const.ts` and change `CAST_DEV` to `true` and `CAST_DEV_APP_ID` to the ID of the app you just created.
+Open `src/cast/dev_const.ts` and change `CAST_DEV_APP_ID` to the ID of the app you just created. And set the `CAST_DEV_HASS_URL` to the url of you development machine.
### Changing configuration
diff --git a/src/cast/cast_manager.ts b/src/cast/cast_manager.ts
index 87404d3841..6c9ea0a8e1 100644
--- a/src/cast/cast_manager.ts
+++ b/src/cast/cast_manager.ts
@@ -1,5 +1,6 @@
import { castApiAvailable } from "./cast_framework";
-import { CAST_APP_ID, CAST_NS, CAST_DEV_HASS_URL, CAST_DEV } from "./const";
+import { CAST_APP_ID, CAST_NS, CAST_DEV } from "./const";
+import { CAST_DEV_HASS_URL } from "./dev_const";
import {
castSendAuth,
HassMessage as ReceiverMessage,
diff --git a/src/cast/const.ts b/src/cast/const.ts
index 784c159a72..fe578e8ad1 100644
--- a/src/cast/const.ts
+++ b/src/cast/const.ts
@@ -1,11 +1,7 @@
+import { CAST_DEV_APP_ID } from "./dev_const";
+
// Guard dev mode with `__dev__` so it can only ever be enabled in dev mode.
export const CAST_DEV = __DEV__ && true;
-// Replace this with your own unpublished cast app that points at your local dev
-const CAST_DEV_APP_ID = "5FE44367";
+
export const CAST_APP_ID = CAST_DEV ? CAST_DEV_APP_ID : "B12CE3CA";
export const CAST_NS = "urn:x-cast:com.nabucasa.hast";
-
-// Chromecast SDK will only load on localhost and HTTPS
-// So during local development we have to send our dev IP address,
-// but then run the UI on localhost.
-export const CAST_DEV_HASS_URL = "http://192.168.1.234:8123";
diff --git a/src/cast/dev_const.ts b/src/cast/dev_const.ts
new file mode 100644
index 0000000000..0e87495ce8
--- /dev/null
+++ b/src/cast/dev_const.ts
@@ -0,0 +1,7 @@
+// Replace this with your own unpublished cast app that points at your local dev
+export const CAST_DEV_APP_ID = "5FE44367";
+
+// Chromecast SDK will only load on localhost and HTTPS
+// So during local development we have to send our dev IP address,
+// but then run the UI on localhost.
+export const CAST_DEV_HASS_URL = "http://192.168.1.234:8123";
diff --git a/src/cast/receiver_messages.ts b/src/cast/receiver_messages.ts
index 529d5e4e70..b3d96c712b 100644
--- a/src/cast/receiver_messages.ts
+++ b/src/cast/receiver_messages.ts
@@ -4,7 +4,8 @@ import { Auth } from "home-assistant-js-websocket";
import { CastManager } from "./cast_manager";
import { BaseCastMessage } from "./types";
-import { CAST_DEV_HASS_URL, CAST_DEV } from "./const";
+import { CAST_DEV } from "./const";
+import { CAST_DEV_HASS_URL } from "./dev_const";
export interface GetStatusMessage extends BaseCastMessage {
type: "get_status";
diff --git a/src/panels/lovelace/special-rows/hui-cast-row.ts b/src/panels/lovelace/special-rows/hui-cast-row.ts
index a71ae295fc..9b5bc7eda2 100644
--- a/src/panels/lovelace/special-rows/hui-cast-row.ts
+++ b/src/panels/lovelace/special-rows/hui-cast-row.ts
@@ -7,6 +7,7 @@ import {
css,
CSSResult,
} from "lit-element";
+import { classMap } from "lit-html/directives/class-map";
import { EntityRow, CastConfig } from "../entity-rows/types";
import { HomeAssistant } from "../../../types";
@@ -45,6 +46,11 @@ class HuiCastRow extends LitElement implements EntityRow {
return html``;
}
+ const active =
+ this._castManager &&
+ this._castManager.status &&
+ this._config.view === this._castManager.status.lovelacePath;
+
return html`