mirror of
https://github.com/home-assistant/frontend.git
synced 2025-07-28 19:56:42 +00:00
Update history and logbook panel path when making selections (#11428)
This commit is contained in:
parent
0df9e9932f
commit
02754369a6
@ -12,7 +12,11 @@ import {
|
|||||||
} from "date-fns";
|
} from "date-fns";
|
||||||
import { css, html, LitElement, PropertyValues } from "lit";
|
import { css, html, LitElement, PropertyValues } from "lit";
|
||||||
import { property, state } from "lit/decorators";
|
import { property, state } from "lit/decorators";
|
||||||
import { extractSearchParam } from "../../common/url/search-params";
|
import { navigate } from "../../common/navigate";
|
||||||
|
import {
|
||||||
|
createSearchParam,
|
||||||
|
extractSearchParam,
|
||||||
|
} from "../../common/url/search-params";
|
||||||
import { computeRTL } from "../../common/util/compute_rtl";
|
import { computeRTL } from "../../common/util/compute_rtl";
|
||||||
import "../../components/chart/state-history-charts";
|
import "../../components/chart/state-history-charts";
|
||||||
import "../../components/entity/ha-entity-picker";
|
import "../../components/entity/ha-entity-picker";
|
||||||
@ -144,6 +148,10 @@ class HaPanelHistory extends LitElement {
|
|||||||
if (startDate) {
|
if (startDate) {
|
||||||
this._startDate = new Date(startDate);
|
this._startDate = new Date(startDate);
|
||||||
}
|
}
|
||||||
|
const endDate = extractSearchParam("end_date");
|
||||||
|
if (endDate) {
|
||||||
|
this._endDate = new Date(endDate);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected updated(changedProps: PropertyValues) {
|
protected updated(changedProps: PropertyValues) {
|
||||||
@ -191,10 +199,32 @@ class HaPanelHistory extends LitElement {
|
|||||||
endDate.setMilliseconds(endDate.getMilliseconds() - 1);
|
endDate.setMilliseconds(endDate.getMilliseconds() - 1);
|
||||||
}
|
}
|
||||||
this._endDate = endDate;
|
this._endDate = endDate;
|
||||||
|
|
||||||
|
this._updatePath();
|
||||||
}
|
}
|
||||||
|
|
||||||
private _entityPicked(ev) {
|
private _entityPicked(ev) {
|
||||||
this._entityId = ev.target.value;
|
this._entityId = ev.target.value;
|
||||||
|
|
||||||
|
this._updatePath();
|
||||||
|
}
|
||||||
|
|
||||||
|
private _updatePath() {
|
||||||
|
const params: Record<string, string> = {};
|
||||||
|
|
||||||
|
if (this._entityId) {
|
||||||
|
params.entity_id = this._entityId;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._startDate) {
|
||||||
|
params.start_date = this._startDate.toISOString();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._endDate) {
|
||||||
|
params.end_date = this._endDate.toISOString();
|
||||||
|
}
|
||||||
|
|
||||||
|
navigate(`/history?${createSearchParam(params)}`, { replace: true });
|
||||||
}
|
}
|
||||||
|
|
||||||
static get styles() {
|
static get styles() {
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
import { mdiRefresh } from "@mdi/js";
|
import { mdiRefresh } from "@mdi/js";
|
||||||
import "@polymer/app-layout/app-header/app-header";
|
import "@polymer/app-layout/app-header/app-header";
|
||||||
import "@polymer/app-layout/app-toolbar/app-toolbar";
|
import "@polymer/app-layout/app-toolbar/app-toolbar";
|
||||||
import { css, html, LitElement, PropertyValues } from "lit";
|
|
||||||
import { customElement, property, state } from "lit/decorators";
|
|
||||||
import {
|
import {
|
||||||
addDays,
|
addDays,
|
||||||
endOfToday,
|
endOfToday,
|
||||||
@ -12,8 +10,15 @@ import {
|
|||||||
startOfWeek,
|
startOfWeek,
|
||||||
startOfYesterday,
|
startOfYesterday,
|
||||||
} from "date-fns";
|
} from "date-fns";
|
||||||
|
import { css, html, LitElement, PropertyValues } from "lit";
|
||||||
|
import { customElement, property, state } from "lit/decorators";
|
||||||
import { isComponentLoaded } from "../../common/config/is_component_loaded";
|
import { isComponentLoaded } from "../../common/config/is_component_loaded";
|
||||||
import { computeStateDomain } from "../../common/entity/compute_state_domain";
|
import { computeStateDomain } from "../../common/entity/compute_state_domain";
|
||||||
|
import { navigate } from "../../common/navigate";
|
||||||
|
import {
|
||||||
|
createSearchParam,
|
||||||
|
extractSearchParam,
|
||||||
|
} from "../../common/url/search-params";
|
||||||
import { computeRTL } from "../../common/util/compute_rtl";
|
import { computeRTL } from "../../common/util/compute_rtl";
|
||||||
import "../../components/entity/ha-entity-picker";
|
import "../../components/entity/ha-entity-picker";
|
||||||
import "../../components/ha-circular-progress";
|
import "../../components/ha-circular-progress";
|
||||||
@ -33,7 +38,6 @@ import "../../layouts/ha-app-layout";
|
|||||||
import { haStyle } from "../../resources/styles";
|
import { haStyle } from "../../resources/styles";
|
||||||
import { HomeAssistant } from "../../types";
|
import { HomeAssistant } from "../../types";
|
||||||
import "./ha-logbook";
|
import "./ha-logbook";
|
||||||
import { extractSearchParam } from "../../common/url/search-params";
|
|
||||||
|
|
||||||
@customElement("ha-panel-logbook")
|
@customElement("ha-panel-logbook")
|
||||||
export class HaPanelLogbook extends LitElement {
|
export class HaPanelLogbook extends LitElement {
|
||||||
@ -166,6 +170,10 @@ export class HaPanelLogbook extends LitElement {
|
|||||||
if (startDate) {
|
if (startDate) {
|
||||||
this._startDate = new Date(startDate);
|
this._startDate = new Date(startDate);
|
||||||
}
|
}
|
||||||
|
const endDate = extractSearchParam("end_date");
|
||||||
|
if (endDate) {
|
||||||
|
this._endDate = new Date(endDate);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected updated(changedProps: PropertyValues<this>) {
|
protected updated(changedProps: PropertyValues<this>) {
|
||||||
@ -223,10 +231,32 @@ export class HaPanelLogbook extends LitElement {
|
|||||||
endDate.setMilliseconds(endDate.getMilliseconds() - 1);
|
endDate.setMilliseconds(endDate.getMilliseconds() - 1);
|
||||||
}
|
}
|
||||||
this._endDate = endDate;
|
this._endDate = endDate;
|
||||||
|
|
||||||
|
this._updatePath();
|
||||||
}
|
}
|
||||||
|
|
||||||
private _entityPicked(ev) {
|
private _entityPicked(ev) {
|
||||||
this._entityId = ev.target.value;
|
this._entityId = ev.target.value;
|
||||||
|
|
||||||
|
this._updatePath();
|
||||||
|
}
|
||||||
|
|
||||||
|
private _updatePath() {
|
||||||
|
const params: Record<string, string> = {};
|
||||||
|
|
||||||
|
if (this._entityId) {
|
||||||
|
params.entity_id = this._entityId;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._startDate) {
|
||||||
|
params.start_date = this._startDate.toISOString();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._endDate) {
|
||||||
|
params.end_date = this._endDate.toISOString();
|
||||||
|
}
|
||||||
|
|
||||||
|
navigate(`/logbook?${createSearchParam(params)}`, { replace: true });
|
||||||
}
|
}
|
||||||
|
|
||||||
private _refreshLogbook() {
|
private _refreshLogbook() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user