Skip to content

Commit

Permalink
WIP
Browse files Browse the repository at this point in the history
  • Loading branch information
Patrick Kissling committed Oct 13, 2023
1 parent afb06e6 commit 5f38fb8
Show file tree
Hide file tree
Showing 6 changed files with 348 additions and 35 deletions.
4 changes: 3 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
/node_modules/
/.rpt2_cache/
package-lock.json
/dist
/dist
# Sentry Config File
.env.sentry-build-plugin
2 changes: 2 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@
"type": "module",
"dependencies": {
"@lit-labs/scoped-registry-mixin": "^1.0.0",
"@sentry/browser": "^7.73.0",
"@sentry/rollup-plugin": "^2.8.0",
"custom-card-helpers": "^1.8.0",
"home-assistant-js-websocket": "^8.0.0",
"lit": "^2.0.0",
Expand Down
9 changes: 8 additions & 1 deletion rollup.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,15 @@ import { terser } from 'rollup-plugin-terser';
import json from '@rollup/plugin-json'
import image from '@rollup/plugin-image'
import gzipPlugin from 'rollup-plugin-gzip'
import { sentryRollupPlugin } from "@sentry/rollup-plugin"

export default [
{
input: 'src/clock-weather-card.ts',
output: {
dir: 'dist',
format: 'es',
sourcemap: true
},
plugins: [
image(),
Expand All @@ -24,7 +26,12 @@ export default [
exclude: 'node_modules/**',
}),
terser(),
gzipPlugin()
gzipPlugin(),
sentryRollupPlugin({
authToken: process.env.SENTRY_AUTH_TOKEN,
org: process.env.SENTRY_ORG,
project: process.env.SENTRY_PROJECT,
})
]
},
];
24 changes: 19 additions & 5 deletions src/clock-weather-card.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import {
handleAction,
TimeFormat
} from 'custom-card-helpers' // This is a community maintained npm module with common helper functions/types. https://github.com/custom-cards/custom-card-helpers

import {
type ClockWeatherCardConfig,
type MergedClockWeatherCardConfig,
Expand All @@ -31,6 +30,7 @@ import { svg, png } from './images'
import { version } from '../package.json'
import { safeRender } from './helpers'
import { DateTime } from 'luxon'
import * as Sentry from '@sentry/browser'

console.info(
`%c CLOCK-WEATHER-CARD \n%c Version: ${version}`,
Expand All @@ -55,6 +55,18 @@ const gradientMap: Map<number, Rgb> = new Map()
.set(30, new Rgb(255, 150, 79)) // orange
.set(40, new Rgb(255, 192, 159)) // red

Sentry.init({
dsn: 'https://fe6c1f118f256a93acaa8cb90fcb26ee@o4505062260277248.ingest.sentry.io/4506031035645952',

// Alternatively, use `process.env.npm_package_version` for a dynamic release version
// if your build tool supports it.
release: `clock-weather-card@${version}`,
integrations: [new Sentry.BrowserTracing(), new Sentry.Replay(), new Sentry.BrowserProfilingIntegration()],
tracesSampleRate: 1.0,
replaysSessionSampleRate: 1.0,
replaysOnErrorSampleRate: 1.0
})

@customElement('clock-weather-card')
export class ClockWeatherCard extends LitElement {
// https://lit.dev/docs/components/properties/
Expand Down Expand Up @@ -152,10 +164,10 @@ export class ClockWeatherCard extends LitElement {
hasDoubleClick: hasAction(this.config.double_tap_action)
})}
tabindex="0"
.label=${`Clock Weather Card: ${this.config.entity || 'No Entity Defined'}`}
.label=${`Clock Weather Card: ${this.config.entity}`}
>
${this.config.title
? html`
? html`
<div class="card-header">
${this.config.title}
</div>`
Expand Down Expand Up @@ -252,8 +264,10 @@ export class ClockWeatherCard extends LitElement {
const weatherIcon = this.toIcon(weatherState, 'fill', true, 'static')
const tempUnit = this.getWeather().attributes.temperature_unit
const isNow = hourly ? DateTime.now().hour === forecast.datetime.hour : DateTime.now().day === forecast.datetime.day
const minTempDay = Math.round(isNow && currentTemp !== null ? Math.min(currentTemp, forecast.templow) : forecast.templow)
const maxTempDay = Math.round(isNow && currentTemp !== null ? Math.max(currentTemp, forecast.temperature) : forecast.temperature)
const tempLow = Math.min(forecast.templow, window.localStorage.get(`clock-weather-card-${forecast.datetime}-min`))
const tempHigh = Math.min(forecast.temphigh, window.localStorage.get(`clock-weather-card-${forecast.datetime}-`))
const minTempDay = Math.round(isNow && currentTemp !== null ? Math.min(currentTemp, tempLow) : tempLow)
const maxTempDay = Math.round(isNow && currentTemp !== null ? Math.max(currentTemp, tempHigh) : tempHigh)

return html`
<clock-weather-card-forecast-row style="--col-one-size: ${(maxColOneChars * 0.5)}rem;">
Expand Down
2 changes: 2 additions & 0 deletions src/helpers.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
import { html, type TemplateResult } from 'lit'
import * as Sentry from '@sentry/browser'

export function safeRender<T> (renderFn: () => T): T | TemplateResult {
try {
return renderFn()
} catch (e) {
Sentry.captureException(e)
console.error('clock-weather-card - Error while rendering clock-weather-card component:', e)
return html``
}
Expand Down
Loading

0 comments on commit 5f38fb8

Please sign in to comment.