You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Home-AssistantConfig/config/dashboards/infrastructure/partials/website_health_sections.yaml

151 lines
5.8 KiB

######################################################################
# @CCOSTAN - Follow Me on X
# For more info visit https://www.vcloudinfo.com/click-here
# Original Repo : https://github.com/CCOSTAN/Home-AssistantConfig
# -------------------------------------------------------------------
# Infrastructure Partial - Website health sections
# Website uptime + domain expiry + certificate telemetry detail view.
# -------------------------------------------------------------------
# Notes: Keep the first section full-width to avoid whitespace.
######################################################################
# -------------------------------------------------------------------
# Website hero (mandatory first full-width container)
# -------------------------------------------------------------------
- type: grid
column_span: 4
columns: 1
square: false
cards:
- type: custom:layout-card
grid_options:
columns: full
layout_type: custom:grid-layout
layout:
grid-template-columns: repeat(2, minmax(0, 1fr))
grid-auto-flow: row
grid-auto-rows: min-content
grid-gap: 12px
margin: 0
mediaquery:
"(max-width: 900px)":
grid-template-columns: repeat(1, minmax(0, 1fr))
cards:
- type: custom:vertical-stack-in-card
grid_options:
columns: full
card_mod:
style: !include /config/dashboards/infrastructure/card_mod/infra_panel.yaml
cards:
- type: custom:button-card
template: bearstone_infra_panel_header
name: Website Uptime
- type: custom:layout-card
layout_type: custom:grid-layout
layout:
grid-template-columns: repeat(2, minmax(0, 1fr))
grid-auto-flow: row
grid-auto-rows: min-content
grid-gap: 12px
margin: 0
mediaquery:
"(max-width: 900px)":
grid-template-columns: repeat(1, minmax(0, 1fr))
cards:
- type: custom:button-card
template: bearstone_infra_list_row_running
entity: binary_sensor.vcloudinfo_com
name: vcloudinfo.com
icon: mdi:web
state_display: >
[[[ return entity.state === 'on' ? 'UP' : (entity.state || 'unknown').toUpperCase(); ]]]
- type: custom:button-card
template: bearstone_infra_list_row_running
entity: binary_sensor.www_kingcrafthomes_com
name: kingcrafthomes.com
icon: mdi:web
state_display: >
[[[ return entity.state === 'on' ? 'UP' : (entity.state || 'unknown').toUpperCase(); ]]]
- type: custom:button-card
template: bearstone_infra_list_row_running
entity: binary_sensor.bear_stone
name: Bear Stone
icon: mdi:web-check
state_display: >
[[[ return entity.state === 'on' ? 'UP' : (entity.state || 'unknown').toUpperCase(); ]]]
- type: custom:vertical-stack-in-card
grid_options:
columns: full
card_mod:
style: !include /config/dashboards/infrastructure/card_mod/infra_panel.yaml
cards:
- type: custom:button-card
template: bearstone_infra_panel_header
name: Domain Expiry
- type: custom:layout-card
layout_type: custom:grid-layout
layout:
grid-template-columns: repeat(2, minmax(0, 1fr))
grid-auto-flow: row
grid-auto-rows: min-content
grid-gap: 12px
margin: 0
mediaquery:
"(max-width: 900px)":
grid-template-columns: repeat(1, minmax(0, 1fr))
cards:
- type: custom:button-card
template: bearstone_infra_list_row
entity: sensor.vcloudinfo_com_days_until_expiration
name: vcloudinfo.com
icon: mdi:calendar-clock
state_display: >
[[[
const days = states['sensor.vcloudinfo_com_days_until_expiration']?.state ?? 'n/a';
const expRaw = states['sensor.vcloudinfo_com_expires']?.state;
let exp = 'n/a';
const s = String(expRaw ?? '');
if (s && !['unknown','unavailable','none',''].includes(s.toLowerCase())) {
if (/^\d{4}-\d{2}-\d{2}/.test(s)) {
exp = s.slice(0, 10);
} else {
const dt = new Date(s);
if (!Number.isNaN(dt.getTime())) {
const y = dt.getFullYear();
const m = String(dt.getMonth() + 1).padStart(2, '0');
const d = String(dt.getDate()).padStart(2, '0');
exp = `${y}-${m}-${d}`;
}
}
}
return `${days}d | ${exp}`;
]]]
- type: custom:button-card
template: bearstone_infra_list_row
entity: sensor.kingcrafthomes_com_days_until_expiration
name: kingcrafthomes.com
icon: mdi:calendar-clock
state_display: >
[[[
const days = states['sensor.kingcrafthomes_com_days_until_expiration']?.state ?? 'n/a';
const expRaw = states['sensor.kingcrafthomes_com_expires']?.state;
let exp = 'n/a';
const s = String(expRaw ?? '');
if (s && !['unknown','unavailable','none',''].includes(s.toLowerCase())) {
if (/^\d{4}-\d{2}-\d{2}/.test(s)) {
exp = s.slice(0, 10);
} else {
const dt = new Date(s);
if (!Number.isNaN(dt.getTime())) {
const y = dt.getFullYear();
const m = String(dt.getMonth() + 1).padStart(2, '0');
const d = String(dt.getDate()).padStart(2, '0');
exp = `${y}-${m}-${d}`;
}
}
}
return `${days}d | ${exp}`;
]]]

Powered by TurnKey Linux.