[
  {
    "path": ".eslintignore",
    "content": "backup/\ndist/\nnode_modules/\nrollup.config.mjs\nrollup.config copy.js\nrollup.new.config.mjs"
  },
  {
    "path": ".eslintrc.json",
    "content": "{\n  \"root\": true,\n  \"parser\": \"@typescript-eslint/parser\",\n  \"parserOptions\": {\n    \"ecmaVersion\": 2022,\n    \"sourceType\": \"module\"\n  },\n  \"plugins\": [\n    \"@typescript-eslint\"\n  ],\n  \"extends\": [\n    \"eslint:recommended\",\n    \"plugin:@typescript-eslint/recommended\",\n    \"airbnb-base\"\n  ],\n  \"rules\": {\n    \"operator-linebreak\": \"warn\",\n    \"no-trailing-spaces\": \"warn\",\n    \"one-var\": \"warn\",\n    \"one-var-declaration-per-line\": \"warn\",\n    \"dot-notation\": \"warn\",\n    \"max-len\": [\"error\", { \"code\": 150 }],\n    \"eol-last\": [\"error\", \"always\"],\n    \"no-console\": \"off\",\n    \"no-unused-vars\": [\"warn\", { \"args\": \"none\", \"ignoreRestSiblings\": true }],\n    \"nonblock-statement-body-position\": \"warn\",\n    \"@typescript-eslint/no-unused-vars\": \"warn\",\n    \"max-classes-per-file\": [\"warn\", 3],\n    \"import/extensions\": [\"warn\", \"ignorePackages\", {\n      \"ts\": \"never\",\n      \"js\": \"never\"\n    }]\n  },\n  \"settings\": {\n    \"import/resolver\": {\n      \"node\": {\n        \"extensions\": [\".js\", \".ts\", \".jsx\", \".tsx\"]\n      }\n    }\n  },\n  \"env\": {\n    \"browser\": true,\n    \"es2022\": true\n  }\n}\n"
  },
  {
    "path": ".github/workflows/codeql.yml",
    "content": "name: \"CodeQL\"\n\non:\n  push:\n    branches: [ \"master\" ]\n  pull_request:\n    branches: [ \"master\" ]\n  schedule:\n    - cron: \"22 7 * * 0\"\n\njobs:\n  analyze:\n    name: Analyze\n    runs-on: ubuntu-latest\n    permissions:\n      actions: read\n      contents: read\n      security-events: write\n\n    strategy:\n      fail-fast: false\n      matrix:\n        language: [ javascript ]\n\n    steps:\n      - name: Checkout\n        uses: actions/checkout@v3\n\n      - name: Initialize CodeQL\n        uses: github/codeql-action/init@v2\n        with:\n          languages: ${{ matrix.language }}\n          queries: +security-and-quality\n\n      - name: Autobuild\n        uses: github/codeql-action/autobuild@v2\n\n      - name: Perform CodeQL Analysis\n        uses: github/codeql-action/analyze@v2\n        with:\n          category: \"/language:${{ matrix.language }}\"\n"
  },
  {
    "path": ".gitignore",
    "content": "# ####### ####### #######\n# Folders\n\n.idea\n__pycache__\n/node_modules/\n/.rpt2_cache/\n/trash/\n/backup/\n\n# ####### ####### #######\n# Files\npackage-lock.json\n\n"
  },
  {
    "path": ".npmignore",
    "content": "# OS X\n.DS_Store\nbackup"
  },
  {
    "path": ".vscode/settings.json",
    "content": "{\n    \"eslint.enable\": true,\n    \"eslint.validate\": [\n      \"javascript\",\n      \"javascriptreact\",\n      \"typescript\",\n      \"typescriptreact\"\n    ],\n    \"editor.tabSize\": 2,\n\n    \"ha_module_path\": \"/home/drp/homeassistant/www/community/ha-card-weather-conditions\",\n    \"editor.wordWrap\": \"wordWrapColumn\",\n    \"editor.wordWrapColumn\": 120,\n  }\n  "
  },
  {
    "path": "CHANGELOG.md",
    "content": "# HA (Lovelace) Card Weather Conditions\n\nThe format is based on [Keep a Changelog](http://keepachangelog.com/)\nand this project adheres to [Semantic Versioning](http://semver.org/).\n\n## [2.0.1] 2025-06-08\n### Fixed\n\n### Added\n- ru locale\n\n### Changed\n- nl locale\n\n## [2.0.0] 2025-06-08\n### Changed\n- Readme and PNG image\n- Fully reengineered the card\n- Czech locale\n\n### Changed\n- Update Spanish locale\n\n## [1.9.12] 2021-01-29\n### Fixed\n- Minor bug fixing\n\n## [1.9.11] 2021-01-29\n### Fixed\n- Minor bug fixing\n\n## [1.9.10] 2021-01-24\n### Changed\nUpdate ClimaCel icons map\n\n## [1.9.9] 2021-01-11\n### Added\n- Norwegian locale\n\n## [1.9.8] 2021-01-07\n### Added\n- Danish locale\n\n## [1.9.7] 2020-12-06\n### Fixed\n- Fixed the snow icon name for the night time (climacell, darksky, openweathermap)\n\n## [1.9.6] 2020-08-17\n### Fixed\n- German locale, fix for \"Feels Like\" word\n\n## [1.9.6] 2020-08-08\n### Added\n- Icon model for: buienradar, defaulthass\n\n## [1.9.5] 2020-08-08\n### Fixed\n- Documentation\n\n## [1.9.5] 2020-07-21\n### Added\n- Errors catch and display while loading translations files\n\n## [1.9.4] 2020-07-19\n### Fixed\n- Minor bug fixing\n\n## [1.9.3] 2020-07-18\n### Changed\n- Exposition time change from hours to minutes\n\n## [1.9.2] 2020-07-10\n### Fixed\n- Minor bug fixing\n\n## [1.9.1] 2020-06-22\n### Added\n- Added icon override mode for the pollen layer\n\n## [1.9.0] 2020-06-21\n### Fixed\n- Minor bug fixing\n\n### Added\n- Add `sea` Weather Forecast session\n\n## [1.8.1] 2020-06-15\n### Fixed\n- Minor bug fixing\n\n## [1.8.0] 2020-06-15\n### Fixed\n- Minor bug fixing\n\n### Changed\n- Internationalization model \n\n### Added\n- Add `pt` language\n- Add Alert Layer\n\n### Changed\n## [1.7.1] 2020-05-24\n### Fixed\n- Minor bug fixing\n\n## [1.7.0] 2020-05-23\n### Fixed\n- Minor bug fixing\n\n### Added\n- Add `sr-latn` language\n\n## [1.6.0] 2020-05-22\n### Added\n- Add `fr` language\n\n## [1.5.1] 2020-05-21\n### Fixed\n- Minor bug fixing\n\n## [1.5.0] 2020-05-14\n### Fixed\n- Minor bug fixing\n### Added\n- Add `uv` (ultraviolet) session\n\n## [1.4.0] 2020-05-13\n### Added\n- Add `es` language\n\n## [1.3.1] 2020-05-13\n### Fixed\n- Minor bug fixing\n\n## [1.3.0] 2020-05-10\n### Added\n- Add moon phase\n\n## [1.2.0] 2020-05-08\n### Added\n- Add NL (Dutch) language\n\n## [1.1.0] 2020-05-07\n### Added\n- Add feels_like sensor\n\n## [1.0.1] 2020-05-07\n### Fixed\n- Minor bug fixing\n\n## [1.0.0] 2020-05-03\n- Initial stable version"
  },
  {
    "path": "LICENSE",
    "content": "MIT License\n\nCopyright (c) 2019 Renato Rossi, https://www.linkedin.com/in/renatorossi/\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n"
  },
  {
    "path": "README.md",
    "content": "# Weather Conditions Card\nha-card-weather-conditions is a powerful and flexible Lovelace card for Home Assistant. It integrates a variety of weather-related data sources to present a comprehensive summary and forecast.<br>\n\n[![hacs_badge](https://img.shields.io/badge/HACS-Default-orange.svg)](https://github.com/hacs/integration)\n\n[![License][license-shield]](LICENSE)\n[![Total alerts](https://img.shields.io/lgtm/alerts/g/r-renato/ha-card-weather-conditions.svg?logo=lgtm&logoWidth=18)](https://lgtm.com/projects/g/r-renato/ha-card-weather-conditions/alerts/)\n[![Language grade: JavaScript](https://img.shields.io/lgtm/grade/javascript/g/r-renato/ha-card-weather-conditions.svg?logo=lgtm&logoWidth=18)](https://lgtm.com/projects/g/r-renato/ha-card-weather-conditions/context:javascript)\n\n[![BuyMeCoffee][buymecoffeebadge]][buymecoffee]\n\n## Features\n\n* Current and forecast weather conditions\n* Marine forecast (swell, wave, wind)\n* Ultraviolet radiation index and protection advice\n* Pollen level display (tree, weed, grass)\n* Air quality index with multiple pollutant types\n* Weather alerts (fire, storm, hydrogeological, hydraulic)\n* Meteogram and camera integration\n* Multilingual support\n* Display MeteoAlarm (Early Warnings for Europe) and Dipartimento Protezione Civile (Italy only) Alert\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-overview.png\" width=\"100%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n<!-- <p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-full.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-1.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-2.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>     -->\n\n## **Card Configuration**\n\nTo use the ```ha-card-weather-conditions``` card, add the following configuration to your ```lovelace``` dashboard:\n\n```yaml\nresources:\n  # Required: Load the card if installed via HACS\n  - url: /hacsfiles/ha-card-weather-conditions/ha-card-weather-conditions.js\n    type: module\n  # Optional: Load Card Mod to enable advanced styling/customization\n  - url: /hacsfiles/lovelace-card-mod/card-mod.js\n    type: module\n  # ...\n```\n\n## **Card Schema Summary**\n\n| **Parameter** | **Type**  | **Required** | **Default** | **Description**                                                                                            |\n| ------------- | --------- | ------------ | ----------- | ---------------------------------------------------------------------------------------------------------- |\n| `type`        | `string`  | Yes          | —           | Must be set to `custom:ha-card-weather-conditions`.                                                        |\n| `language`    | `string`  | No           | `en`        | Language for labels. Supported values: `en`, `it`, `nl`, `es`, `de`, `fr`, `sr-latn`, `pt`, `da`, `no-NO`, `cs`, `ru`. |\n| `weather`     | `object`  | No           | —           | Configuration for main weather source. See dedicated section.                                              |\n| `ultraviolet` | `object`  | No           | —           | Configuration for UV index display. See dedicated section for details.                                     |\n| `pollen`      | `object`  | No           | —           | Configuration for pollen levels. See dedicated section.                                                    |\n| `airquality`  | `object`  | No           | —           | Configuration for air quality index. See dedicated section.                                                |\n| `camera`      | `string`  | No           | —           | Entity ID of the camera to display.                                                                        |\n\n## **1 `weather` Object Schema**\nThe following parameters configure the weather object to display current conditions, short-term and long-term forecasts, as well as related alerts.\nThis card has been tested with weather data provided by `pirateweather`, `climacell`, `darksky` and `openweathermap` integrations.\n| **Name**                  | **Type**  | **Required** | **Default**     | **Description**                                                                                                            |\n| ------------------------- | --------- | ------------ | --------------- | -------------------------------------------------------------------------------------------------------------------------- |\n| `name`                    | `string`  | No           | —               | Name of the location displayed in the summary section.                                                                     |\n| `sun`                     | `string`  | No           | —               | Entity ID for the sun sensor (used to adjust visuals for daylight, sunrise, and sunset).                                   |\n| `moonphase`               | `string`  | No           | —               | Entity ID for the moon phase sensor.                                                                                       |\n| `icons_model`             | `string`  | **Yes**      | `pirateweather` | Icon set to use. Supported values: `pirateweather`, `climacell`, `darksky`, `openweathermap`, `buienradar`, `defaulthass`. |\n| `animation`               | `boolean` | No           | `false`         | Enables visual effects like moving clouds, rain, or waves based on weather conditions.                                     |\n| `present`                 | `object`  | No           | —               | Object containing current weather data (e.g., temperature, humidity, pressure).                                            |\n| `daily_forecasts`         | `object`  | No           | —               | Object containing multi-day weather forecast data.                                                                         |\n| `hourly_forecasts`        | `object`  | No           | —               | Object containing hourly weather forecast data.                                                                            |\n| `marine_daily_forecasts`  | `object`  | No           | —               | Object with daily marine forecast data (e.g., wave height, wind, tides).                                                   |\n| `marine_hourly_forecasts` | `object`  | No           | —               | Object with hourly marine forecast data.                                                                                   |\n| `meteoalarm`              | `string`  | No           | —               | Entity ID from [Meteoalarm](https://meteoalarm.org/) integration for regional weather warnings.                            |\n| `dpcalarm`                | `object`  | No           | —               | Object providing DPC (Protezione Civile) alerts such as thunderstorm or flood risks.                                       |\n\n### **1.1 `present` Object Schema**\nThe present object defines the entities used to display the current weather conditions in the summary section of the card. Each property corresponds to a specific sensor or attribute providing real-time environmental data.\n| **Name**                    |  **Type**  | **Required** | **Default** | **Description**                                                               |\n| --------------------------- | ---------- | ------------ | ----------- | ----------------------------------------------------------------------------- |\n| `condition`                 | `string`   | No           | —           | Entity ID providing the current weather condition (e.g. sunny, cloudy, rain). |\n| `temperature`               | `string`   | No           | —           | Entity ID providing the current temperature.                                  |\n| `temperature_feelslike`     | `string`   | No           | —           | Entity ID providing the perceived (feels-like) temperature.                   |\n| `temperature_min`           | `string`   | No           | —           | Entity ID providing the minimum temperature of the day.                       |\n| `temperature_max`           | `string`   | No           | —           | Entity ID providing the maximum temperature of the day.                       |\n| `humidity`                  | `string`   | No           | —           | Entity ID providing the current humidity level (%).                           |\n| `pressure`                  | `string`   | No           | —           | Entity ID providing the current atmospheric pressure.                         |\n| `visibility`                | `string`   | No           | —           | Entity ID providing the current visibility level.                             |\n| `wind_bearing`              | `string`   | No           | —           | Entity ID providing the wind direction in degrees.                            |\n| `wind_speed`                | `string`   | No           | —           | Entity ID providing the wind speed.                                           |\n| `precipitation_intensity`   | `string`   | No           | —           | Entity ID providing the precipitation rate (e.g. mm/h).                       |\n| `precipitation_probability` | `string`   | No           | —           | Entity ID providing the probability of precipitation (%).                     |\n\n### **1.2 `daily_forecasts` Object Schema**\nThis object defines the structure for multi-day forecast data, where each property can include multiple time slots (e.g. `day_1`, `day_2`, `day_3`…).\nEach forecast element (such as `temperature`, `condition`, `precipitation probability`, etc.) must be represented as a Home Assistant entity (e.g., sensor) that includes the following attributes:\n\n- `datetime`: the timestamp indicating the forecast reference time, in ISO 8601 format, for example: <code>2025-06-12T22:00:00+00:00</code>\n\n- `unit_of_measurement`: the unit of measure for the forecasted value (e.g., \"`°C`\", \"`mm`\", \"`%`\"), which must be exposed as an attribute of the sensor.\n\nThese attributes are essential to ensure accurate time alignment and proper rendering of the forecast data.\n\n| **Name**                    | **Type**     | **Required** | **Default** | **Description**                                                            |\n| --------------------------- | ------------ | ------------ | ----------- | -------------------------------------------------------------------------- |\n| `condition`                 | `iTimeSlots` | No           | —           | Object containing the weather condition icons or states for each day slot. |\n| `temperature_high`          | `iTimeSlots` | No           | —           | Object containing the daily high temperature values per slot.              |\n| `temperature_low`           | `iTimeSlots` | No           | —           | Object containing the daily low temperature values per slot.               |\n| `precipitation_intensity`   | `iTimeSlots` | No           | —           | Object with the forecasted precipitation amount for each slot.             |\n| `precipitation_probability` | `iTimeSlots` | No           | —           | Object with the probability of precipitation (%) per slot.                 |\n\n### **1.3 `hourly_forecasts` Object Schema**\nThis object defines the structure for hourly weather forecast data. All fields are optional and do not have default values.\nEach forecast element (such as `temperature`, `condition`, `precipitation probability`, etc.) must be represented as a Home Assistant entity (e.g., sensor) that includes the following attributes:\n\n- `datetime`: the timestamp indicating the forecast reference time, in ISO 8601 format, for example: <code>2025-06-12T22:00:00+00:00</code>\n\n- `unit_of_measurement`: the unit of measure for the forecasted value (e.g., \"`°C`\", \"`mm`\", \"`%`\"), which must be exposed as an attribute of the sensor.\n\nThese attributes are essential to ensure accurate time alignment and proper rendering of the forecast data.\n\n| **Name**                    | **Type**     | **Required** | **Default** | **Description**                                                               |\n| --------------------------- | ------------ | ------------ | ----------- | ----------------------------------------------------------------------------- |\n| `condition`                 | `iTimeSlots` | No           | —           | Object containing the weather condition icons or states for each hourly slot. |\n| `temperature`               | `iTimeSlots` | No           | —           | Object containing the perceived ambient temperature for each hour.            |\n| `temperature_feelslike`     | `iTimeSlots` | No           | —           | Object containing the \"feels like\" temperature values for each hour.          |\n| `precipitation_intensity`   | `iTimeSlots` | No           | —           | Object with forecasted precipitation amount per hour.                         |\n| `precipitation_probability` | `iTimeSlots` | No           | —           | Object with probability of precipitation (%) per hour.                        |\n| `wind_bearing`              | `iTimeSlots` | No           | —           | Object with wind direction (in degrees or cardinal direction) per hour.       |\n| `wind_speed`                | `iTimeSlots` | No           | —           | Object with wind speed values per hour.                                       |\n\n### **1.3.1 `iTimeSlots` Object Schema**\nThis object represents a set of six time slots used to store sequential forecast data (e.g., hourly, daily, etc.).\n| **Name** | **Type** | **Required** | **Description**                                              |\n| -------- | -------- | ------------ | ------------------------------------------------------------ |\n| `slot1`  | `string` | No           | Value for the first time slot (e.g., current or first hour). |\n| `slot2`  | `string` | No           | Value for the second time slot.                              |\n| `slot3`  | `string` | No           | Value for the third time slot.                               |\n| `slot4`  | `string` | No           | Value for the fourth time slot.                              |\n| `slot5`  | `string` | No           | Value for the fifth time slot.                               |\n| `slot6`  | `string` | No           | Value for the sixth time slot.                               |\n\n### **1.4 `dpcalarm` Object Schema**\nThe `dpcalarm` object is used to configure weather-related alerts provided by the Italian Civil Protection Department (DPC), including thunderstorms, hydraulic, and hydrogeological risks. Each property should reference a specific sensor entity ID.\n| **Name**          | **Type** | **Required** | **Description**                                                              |\n| ----------------- | -------- | ------------ | ---------------------------------------------------------------------------- |\n| `thunderstorms`   | `string`   | No           | Entity ID providing thunderstorm alert information from DPC.                 |\n| `hydraulic`       | `string`   | No           | Entity ID providing hydraulic (river/stream flooding) alert information.     |\n| `hydrogeological` | `string`   | No           | Entity ID providing hydrogeological (landslide/soil instability) alert data. |\n\n## **2 `ultraviolet` Object Schema**\nThe ultraviolet object allows you to display UV-related data such as the current index, ozone level, protection window, and safe exposure times for different skin types (I–VI).\n| **Name**            | **Type** | **Required** | **Description**                                                                 |\n| ------------------- | -------- | ------------ | ------------------------------------------------------------------------------- |\n| `protection_window` | `string` | No           | Entity ID providing the time window during which sun protection is recommended. |\n| `ozone_level`       | `string` | No           | Entity ID providing the current atmospheric ozone level.                        |\n| `uv_index`          | `string` | No           | Entity ID providing the current UV index value.                                 |\n| `uv_level`          | `string` | No           | Entity ID describing the UV risk level (e.g. low, moderate, high).              |\n| `max_uv_index`      | `string` | No           | Entity ID providing the maximum forecasted UV index for the day.                |\n| `set_skin_type_1`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type I.           |\n| `set_skin_type_2`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type II.          |\n| `set_skin_type_3`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type III.         |\n| `set_skin_type_4`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type IV.          |\n| `set_skin_type_5`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type V.           |\n| `set_skin_type_6`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type VI.          |\n\n## **3 `pollen` Object Schema**\nThe pollen object provides information about airborne allergens. It defines the range of measured values (`min` and `max`) and includes a list of `entities` describing each pollen type.\n| **Name**   | **Type**        | **Required** | **Description**                                                         |\n| ---------- | --------------- | ------------ | ----------------------------------------------------------------------- |\n| `entities` | `iPollenItem[]` | Yes          | Array of pollen data objects, each representing a specific pollen type. |\n| `min`      | `number`        | Yes          | Minimum expected pollen concentration (used for scaling).               |\n| `max`      | `number`        | Yes          | Maximum expected pollen concentration (used for scaling).               |\n\n## **3.1 `iPollenItem` Object Schema**\nEach `iPollenItem` defines a specific pollen type to be tracked, including a name for display and the corresponding entity ID in Home Assistant.\n| **Name** | **Type** | **Required** | **Description**                                                   |\n| -------- | -------- | ------------ | ----------------------------------------------------------------- |\n| `name`   | `string`   | Yes        | Display name of the pollen type (e.g., “Grass”, “Birch”).         |\n| `entity` | `string`   | Yes        | Home Assistant entity ID providing the pollen concentration data. |\n\n## **4 `airquality` Object Schema**\nThe `airquality` object defines the Home Assistant entity IDs used to monitor various air pollution metrics and EPA health indicators. Each field corresponds to a specific air quality parameter.\n| **Name**                | **Type** | **Required** | **Description**                                                              |\n| ----------------------- | -------- | ------------ | ---------------------------------------------------------------------------- |\n| `pm25`                  | `string` | No           | Entity ID providing PM2.5 (fine particulate matter) concentration.           |\n| `pm10`                  | `string` | No           | Entity ID providing PM10 (coarse particulate matter) concentration.          |\n| `o3`                    | `string` | No           | Entity ID providing Ozone (O₃) concentration.                                |\n| `no2`                   | `string` | No           | Entity ID providing Nitrogen Dioxide (NO₂) concentration.                    |\n| `co`                    | `string` | No           | Entity ID providing Carbon Monoxide (CO) concentration.                      |\n| `so2`                   | `string` | No           | Entity ID providing Sulfur Dioxide (SO₂) concentration.                      |\n| `epa_aqi`               | `string` | No           | Entity ID providing the EPA-computed Air Quality Index.                      |\n| `epa_primary_pollutant` | `string` | No           | Entity ID providing the EPA-designated primary pollutant.                    |\n| `epa_health_concern`    | `string` | No           | Entity ID describing the EPA-assigned health concern level (e.g., moderate). |\n\n## **Card Layers Sample**\nThis section showcases a complete example of the different visual layers supported by the `ha-card-weather-conditions` card.\nEach layer such as summary, weather conditions, air quality, UV index, and alerts—can be configured independently, allowing full control over how and where data appears.\n\nUse this reference as a guide when designing your Lovelace configuration to build a fully personalized weather dashboard.\n\n### **Summary Layer**\nThe summary layers present a concise visual overview of current weather conditions.\n\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-summary.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  name: \"Acquafredda\" \n  icons_model: pirateweather\n  moonphase: sensor.moon_phase\n  present:\n    condition: sensor.home_condition\n    temperature: sensor.home_temperature\n    temperature_feelslike: sensor.home_apparent_temperature\n```\n\n### **Present Layer**\nThis layer displays the current weather conditions using entity data such as temperature, humidity, wind, and more.\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-present.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  sun: sun.sun\n  present:\n    temperature_min: sensor.home_temperature_min\n    temperature_max: sensor.home_temperature_max\n    humidity: sensor.home_relative_humidity\n    pressure: sensor.home_pressure\n    wind_bearing: sensor.home_wind_bearing\n    wind_speed: sensor.home_wind_speed\n    precipitation_intensity: sensor.home_precipitation\n    precipitation_probability: sensor.home_precipitation_probability\n```\n### **Daily Forecast Layer**\nThis layer provides a multi-day weather overview, including expected temperature highs and lows, precipitation probability, and general conditions.\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-daily-forecast.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  daily_forecasts:\n    condition:\n      slot1: sensor.home_daily_forecast_condition_d1\n      slot2: sensor.home_daily_forecast_condition_d2\n      slot3: sensor.home_daily_forecast_condition_d3\n      slot4: sensor.home_daily_forecast_condition_d4                         \n    temperature_high:\n      slot1: sensor.home_daily_forecast_temperature_max_d1\n      slot2: sensor.home_daily_forecast_temperature_max_d2\n      slot3: sensor.home_daily_forecast_temperature_max_d3\n      slot4: sensor.home_daily_forecast_temperature_max_d4\n    temperature_low:\n      slot1: sensor.home_daily_forecast_temperature_min_d1\n      slot2: sensor.home_daily_forecast_temperature_min_d2\n      slot3: sensor.home_daily_forecast_temperature_min_d3\n      slot4: sensor.home_daily_forecast_temperature_min_d4\n    precipitation_probability:\n      slot1: sensor.home_daily_forecast_precipitation_probability_d1\n      slot2: sensor.home_daily_forecast_precipitation_probability_d2\n      slot3: sensor.home_daily_forecast_precipitation_probability_d3\n      slot4: sensor.home_daily_forecast_precipitation_probability_d4\n    precipitation_intensity:\n      slot1: sensor.home_daily_forecast_precipitation_d1\n      slot2: sensor.home_daily_forecast_precipitation_d2\n      slot3: sensor.home_daily_forecast_precipitation_d3\n      slot4: sensor.home_daily_forecast_precipitation_d4\n```\n\n### **Hourly Forecast Layer**\nThis layer displays detailed weather data for the next several hours, including temperature, precipitation, and wind conditions.\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-hourly-forecast.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  hourly_forecasts:\n    condition:\n      slot1: sensor.home_hourly_forecast_condition_h1\n      slot2: sensor.home_hourly_forecast_condition_h2\n      slot3: sensor.home_hourly_forecast_condition_h3\n      slot4: sensor.home_hourly_forecast_condition_h4\n    temperature:\n      slot1: sensor.home_hourly_forecast_temperature_h1\n      slot2: sensor.home_hourly_forecast_temperature_h2\n      slot3: sensor.home_hourly_forecast_temperature_h3\n      slot4: sensor.home_hourly_forecast_temperature_h4\n    temperature_feelslike:\n      slot1: sensor.home_hourly_forecast_apparent_temperature_h1\n      slot2: sensor.home_hourly_forecast_apparent_temperature_h2\n      slot3: sensor.home_hourly_forecast_apparent_temperature_h3\n      slot4: sensor.home_hourly_forecast_apparent_temperature_h4\n    precipitation_intensity:\n      slot1: sensor.home_hourly_forecast_precipitation_h1\n      slot2: sensor.home_hourly_forecast_precipitation_h2\n      slot3: sensor.home_hourly_forecast_precipitation_h3\n      slot4: sensor.home_hourly_forecast_precipitation_h4\n    precipitation_probability:\n      slot1: sensor.home_hourly_forecast_precipitation_probability_h1\n      slot2: sensor.home_hourly_forecast_precipitation_probability_h2\n      slot3: sensor.home_hourly_forecast_precipitation_probability_h3\n      slot4: sensor.home_hourly_forecast_precipitation_probability_h4\n    wind_bearing:\n      slot1: sensor.home_hourly_forecast_wind_bearing_h1\n      slot2: sensor.home_hourly_forecast_wind_bearing_h2\n      slot3: sensor.home_hourly_forecast_wind_bearing_h3\n      slot4: sensor.home_hourly_forecast_wind_bearing_h4\n    wind_speed:\n      slot1: sensor.home_hourly_forecast_wind_speed_h1\n      slot2: sensor.home_hourly_forecast_wind_speed_h2\n      slot3: sensor.home_hourly_forecast_wind_speed_h3\n      slot4: sensor.home_hourly_forecast_wind_speed_h4\n```\n### **Marine Daily Forecast Layer**\nThis layer provides daily marine weather forecasts, including information such as wave height, wind speed, and sea conditions.\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-marine-daily-forecast.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  marine_daily_forecasts:\n    wave_height_max:\n      slot1: sensor.marine_wave_height_max_day_0\n      slot2: sensor.marine_wave_height_max_day_1\n      slot3: sensor.marine_wave_height_max_day_2\n      slot4: sensor.marine_wave_height_max_day_3\n    wave_direction:\n      slot1: sensor.marine_wave_direction_dominant_day_0\n      slot2: sensor.marine_wave_direction_dominant_day_1\n      slot3: sensor.marine_wave_direction_dominant_day_2\n      slot4: sensor.marine_wave_direction_dominant_day_3                            \n    swell_wave_height_max:\n      slot1: sensor.amarine_swell_wave_height_max_day_0\n      slot2: sensor.marine_swell_wave_height_max_day_1\n      slot3: sensor.marine_swell_wave_height_max_day_2\n      slot4: sensor.marine_swell_wave_height_max_day_3                              \n    wind_wave_height_max:\n      slot1: sensor.marine_wind_wave_height_max_day_0\n      slot2: sensor.marine_wind_wave_height_max_day_1\n      slot3: sensor.marine_wind_wave_height_max_day_2\n      slot4: sensor.marine_wind_wave_height_max_day_3 \n```\n### **Alarms Layer**\nThis layer displays weather alerts and warnings from official sources such as Meteoalarm and the Italian Civil Protection Department (DPC). \n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-alarms.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  meteoalarm: binary_sensor.italy_basilicata_meteo_alarm\n  dpcalarm:\n    thunderstorms: binary_sensor.dpc_basilicata_temporali_oggi\n    hydraulic: binary_sensor.dpc_basilicata_idraulico_oggi\n    hydrogeological: binary_sensor.dpc_basilicata_idrogeologico_oggi\n```\n### **Ultraviolet Layer**\nThis layer presents real-time ultraviolet (UV) radiation data, including UV index levels, ozone concentration, and skin protection recommendations.\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-ultraviolet.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nultraviolet:\n  protection_window: binary_sensor.openuv_protection_window\n  ozone_level: sensor.openuv_current_ozone_level\n  uv_index: sensor.openuv_current_uv_index\n  uv_level: sensor.openuv_current_uv_level\n  max_uv_index: sensor.openuv_max_uv_index\n\n  set_skin_type_1: sensor.openuv_skin_type_1_safe_exposure_time\n  set_skin_type_2: sensor.openuv_skin_type_2_safe_exposure_time\n  set_skin_type_3: sensor.openuv_skin_type_3_safe_exposure_time\n  set_skin_type_4: sensor.openuv_skin_type_4_safe_exposure_time\n  set_skin_type_5: sensor.openuv_skin_type_5_safe_exposure_time\n  set_skin_type_6: sensor.openuv_skin_type_6_safe_exposure_time\n```\n### **Pollen Layer**\nThis layer displays information about airborne pollen levels, helping users monitor potential allergen exposure.\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-pollen.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \npollen:\n  min: 1\n  max: 4\n  entities:\n    - name: Alder\n      entity: sensor.openmeteo_pollen_alder_level \n    - name: Birch\n      entity: sensor.openmeteo_pollen_birch_level\n    - name: Grass\n      entity: sensor.openmeteo_pollen_grass_level\n    - name: Mugwort\n      entity: sensor.openmeteo_pollen_mugwort_level\n    - name: Olive\n      entity: sensor.openmeteo_pollen_olive_level \n    - name: Ragweed\n      entity: sensor.openmeteo_pollen_ragweed_level  \n```\n### **Air Quality Layer**\nThis layer presents real-time data on key air quality indicators such as PM2.5, PM10, ozone, and nitrogen dioxide levels.\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-air-quality.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nairquality:\n  pm25: sensor.lazio_italy_pm2_5\n  pm10: sensor.lazio_italy_pm10\n  o3: sensor.roma_lazio_italy_ozone\n  co: sensor.roma_lazio_italy_carbon_monoxide\n  epa_aqi: sensor.lazio_italy_air_quality_index\n  epa_primary_pollutant: sensor.lazio_italy_dominant_pollutant\n```\n\n[license-shield]:https://img.shields.io/github/license/r-renato/ha-card-weather-conditions\n[buymecoffee]: https://www.buymeacoffee.com/0D3WbkKrn\n[buymecoffeebadge]: https://img.shields.io/badge/buy%20me%20a%20coffee-donate-yellow?style=for-the-badge\n"
  },
  {
    "path": "dist/ha-card-weather-conditions.js",
    "content": "function e(e,t,i,n){var a,s=arguments.length,o=s<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,i):n;if(\"object\"==typeof Reflect&&\"function\"==typeof Reflect.decorate)o=Reflect.decorate(e,t,i,n);else for(var r=e.length-1;r>=0;r--)(a=e[r])&&(o=(s<3?a(o):s>3?a(t,i,o):a(t,i))||o);return s>3&&o&&Object.defineProperty(t,i,o),o}\"function\"==typeof SuppressedError&&SuppressedError;\n/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t=globalThis,i=t.ShadowRoot&&(void 0===t.ShadyCSS||t.ShadyCSS.nativeShadow)&&\"adoptedStyleSheets\"in Document.prototype&&\"replace\"in CSSStyleSheet.prototype,n=Symbol(),a=new WeakMap;let s=class{constructor(e,t,i){if(this._$cssResult$=!0,i!==n)throw Error(\"CSSResult is not constructable. Use `unsafeCSS` or `css` instead.\");this.cssText=e,this.t=t}get styleSheet(){let e=this.o;const t=this.t;if(i&&void 0===e){const i=void 0!==t&&1===t.length;i&&(e=a.get(t)),void 0===e&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),i&&a.set(t,e))}return e}toString(){return this.cssText}};const o=(e,...t)=>{const i=1===e.length?e[0]:t.reduce(((t,i,n)=>t+(e=>{if(!0===e._$cssResult$)return e.cssText;if(\"number\"==typeof e)return e;throw Error(\"Value passed to 'css' function must be a 'css' function result: \"+e+\". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.\")})(i)+e[n+1]),e[0]);return new s(i,e,n)},r=i?e=>e:e=>e instanceof CSSStyleSheet?(e=>{let t=\"\";for(const i of e.cssRules)t+=i.cssText;return(e=>new s(\"string\"==typeof e?e:e+\"\",void 0,n))(t)})(e):e\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */,{is:l,defineProperty:c,getOwnPropertyDescriptor:d,getOwnPropertyNames:h,getOwnPropertySymbols:u,getPrototypeOf:p}=Object,m=globalThis,g=m.trustedTypes,y=g?g.emptyScript:\"\",f=m.reactiveElementPolyfillSupport,v=(e,t)=>e,_={toAttribute(e,t){switch(t){case Boolean:e=e?y:null;break;case Object:case Array:e=null==e?e:JSON.stringify(e)}return e},fromAttribute(e,t){let i=e;switch(t){case Boolean:i=null!==e;break;case Number:i=null===e?null:Number(e);break;case Object:case Array:try{i=JSON.parse(e)}catch(e){i=null}}return i}},w=(e,t)=>!l(e,t),$={attribute:!0,type:String,converter:_,reflect:!1,useDefault:!1,hasChanged:w};Symbol.metadata??=Symbol(\"metadata\"),m.litPropertyMetadata??=new WeakMap;let x=class extends HTMLElement{static addInitializer(e){this._$Ei(),(this.l??=[]).push(e)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(e,t=$){if(t.state&&(t.attribute=!1),this._$Ei(),this.prototype.hasOwnProperty(e)&&((t=Object.create(t)).wrapped=!0),this.elementProperties.set(e,t),!t.noAccessor){const i=Symbol(),n=this.getPropertyDescriptor(e,i,t);void 0!==n&&c(this.prototype,e,n)}}static getPropertyDescriptor(e,t,i){const{get:n,set:a}=d(this.prototype,e)??{get(){return this[t]},set(e){this[t]=e}};return{get:n,set(t){const s=n?.call(this);a?.call(this,t),this.requestUpdate(e,s,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)??$}static _$Ei(){if(this.hasOwnProperty(v(\"elementProperties\")))return;const e=p(this);e.finalize(),void 0!==e.l&&(this.l=[...e.l]),this.elementProperties=new Map(e.elementProperties)}static finalize(){if(this.hasOwnProperty(v(\"finalized\")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(v(\"properties\"))){const e=this.properties,t=[...h(e),...u(e)];for(const i of t)this.createProperty(i,e[i])}const e=this[Symbol.metadata];if(null!==e){const t=litPropertyMetadata.get(e);if(void 0!==t)for(const[e,i]of t)this.elementProperties.set(e,i)}this._$Eh=new Map;for(const[e,t]of this.elementProperties){const i=this._$Eu(e,t);void 0!==i&&this._$Eh.set(i,e)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(e){const t=[];if(Array.isArray(e)){const i=new Set(e.flat(1/0).reverse());for(const e of i)t.unshift(r(e))}else void 0!==e&&t.push(r(e));return t}static _$Eu(e,t){const i=t.attribute;return!1===i?void 0:\"string\"==typeof i?i:\"string\"==typeof e?e.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise((e=>this.enableUpdating=e)),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach((e=>e(this)))}addController(e){(this._$EO??=new Set).add(e),void 0!==this.renderRoot&&this.isConnected&&e.hostConnected?.()}removeController(e){this._$EO?.delete(e)}_$E_(){const e=new Map,t=this.constructor.elementProperties;for(const i of t.keys())this.hasOwnProperty(i)&&(e.set(i,this[i]),delete this[i]);e.size>0&&(this._$Ep=e)}createRenderRoot(){const e=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return((e,n)=>{if(i)e.adoptedStyleSheets=n.map((e=>e instanceof CSSStyleSheet?e:e.styleSheet));else for(const i of n){const n=document.createElement(\"style\"),a=t.litNonce;void 0!==a&&n.setAttribute(\"nonce\",a),n.textContent=i.cssText,e.appendChild(n)}})(e,this.constructor.elementStyles),e}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach((e=>e.hostConnected?.()))}enableUpdating(e){}disconnectedCallback(){this._$EO?.forEach((e=>e.hostDisconnected?.()))}attributeChangedCallback(e,t,i){this._$AK(e,i)}_$ET(e,t){const i=this.constructor.elementProperties.get(e),n=this.constructor._$Eu(e,i);if(void 0!==n&&!0===i.reflect){const a=(void 0!==i.converter?.toAttribute?i.converter:_).toAttribute(t,i.type);this._$Em=e,null==a?this.removeAttribute(n):this.setAttribute(n,a),this._$Em=null}}_$AK(e,t){const i=this.constructor,n=i._$Eh.get(e);if(void 0!==n&&this._$Em!==n){const e=i.getPropertyOptions(n),a=\"function\"==typeof e.converter?{fromAttribute:e.converter}:void 0!==e.converter?.fromAttribute?e.converter:_;this._$Em=n,this[n]=a.fromAttribute(t,e.type)??this._$Ej?.get(n)??null,this._$Em=null}}requestUpdate(e,t,i){if(void 0!==e){const n=this.constructor,a=this[e];if(i??=n.getPropertyOptions(e),!((i.hasChanged??w)(a,t)||i.useDefault&&i.reflect&&a===this._$Ej?.get(e)&&!this.hasAttribute(n._$Eu(e,i))))return;this.C(e,t,i)}!1===this.isUpdatePending&&(this._$ES=this._$EP())}C(e,t,{useDefault:i,reflect:n,wrapped:a},s){i&&!(this._$Ej??=new Map).has(e)&&(this._$Ej.set(e,s??t??this[e]),!0!==a||void 0!==s)||(this._$AL.has(e)||(this.hasUpdated||i||(t=void 0),this._$AL.set(e,t)),!0===n&&this._$Em!==e&&(this._$Eq??=new Set).add(e))}async _$EP(){this.isUpdatePending=!0;try{await this._$ES}catch(e){Promise.reject(e)}const e=this.scheduleUpdate();return null!=e&&await e,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(const[e,t]of this._$Ep)this[e]=t;this._$Ep=void 0}const e=this.constructor.elementProperties;if(e.size>0)for(const[t,i]of e){const{wrapped:e}=i,n=this[t];!0!==e||this._$AL.has(t)||void 0===n||this.C(t,void 0,i,n)}}let e=!1;const t=this._$AL;try{e=this.shouldUpdate(t),e?(this.willUpdate(t),this._$EO?.forEach((e=>e.hostUpdate?.())),this.update(t)):this._$EM()}catch(t){throw e=!1,this._$EM(),t}e&&this._$AE(t)}willUpdate(e){}_$AE(e){this._$EO?.forEach((e=>e.hostUpdated?.())),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(e)),this.updated(e)}_$EM(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(e){return!0}update(e){this._$Eq&&=this._$Eq.forEach((e=>this._$ET(e,this[e]))),this._$EM()}updated(e){}firstUpdated(e){}};x.elementStyles=[],x.shadowRootOptions={mode:\"open\"},x[v(\"elementProperties\")]=new Map,x[v(\"finalized\")]=new Map,f?.({ReactiveElement:x}),(m.reactiveElementVersions??=[]).push(\"2.1.0\");\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst b=globalThis,A=b.trustedTypes,z=A?A.createPolicy(\"lit-html\",{createHTML:e=>e}):void 0,E=\"$lit$\",k=`lit$${Math.random().toFixed(9).slice(2)}$`,S=\"?\"+k,C=`<${S}>`,I=document,N=()=>I.createComment(\"\"),P=e=>null===e||\"object\"!=typeof e&&\"function\"!=typeof e,T=Array.isArray,U=\"[ \\t\\n\\f\\r]\",D=/<(?:(!--|\\/[^a-zA-Z])|(\\/?[a-zA-Z][^>\\s]*)|(\\/?$))/g,O=/-->/g,M=/>/g,L=RegExp(`>|${U}(?:([^\\\\s\"'>=/]+)(${U}*=${U}*(?:[^ \\t\\n\\f\\r\"'\\`<>=]|(\"|')|))|$)`,\"g\"),j=/'/g,R=/\"/g,H=/^(?:script|style|textarea|title)$/i,F=(e=>(t,...i)=>({_$litType$:e,strings:t,values:i}))(1),V=Symbol.for(\"lit-noChange\"),W=Symbol.for(\"lit-nothing\"),B=new WeakMap,q=I.createTreeWalker(I,129);function Z(e,t){if(!T(e)||!e.hasOwnProperty(\"raw\"))throw Error(\"invalid template strings array\");return void 0!==z?z.createHTML(t):t}const J=(e,t)=>{const i=e.length-1,n=[];let a,s=2===t?\"<svg>\":3===t?\"<math>\":\"\",o=D;for(let t=0;t<i;t++){const i=e[t];let r,l,c=-1,d=0;for(;d<i.length&&(o.lastIndex=d,l=o.exec(i),null!==l);)d=o.lastIndex,o===D?\"!--\"===l[1]?o=O:void 0!==l[1]?o=M:void 0!==l[2]?(H.test(l[2])&&(a=RegExp(\"</\"+l[2],\"g\")),o=L):void 0!==l[3]&&(o=L):o===L?\">\"===l[0]?(o=a??D,c=-1):void 0===l[1]?c=-2:(c=o.lastIndex-l[2].length,r=l[1],o=void 0===l[3]?L:'\"'===l[3]?R:j):o===R||o===j?o=L:o===O||o===M?o=D:(o=L,a=void 0);const h=o===L&&e[t+1].startsWith(\"/>\")?\" \":\"\";s+=o===D?i+C:c>=0?(n.push(r),i.slice(0,c)+E+i.slice(c)+k+h):i+k+(-2===c?t:h)}return[Z(e,s+(e[i]||\"<?>\")+(2===t?\"</svg>\":3===t?\"</math>\":\"\")),n]};class Y{constructor({strings:e,_$litType$:t},i){let n;this.parts=[];let a=0,s=0;const o=e.length-1,r=this.parts,[l,c]=J(e,t);if(this.el=Y.createElement(l,i),q.currentNode=this.el.content,2===t||3===t){const e=this.el.content.firstChild;e.replaceWith(...e.childNodes)}for(;null!==(n=q.nextNode())&&r.length<o;){if(1===n.nodeType){if(n.hasAttributes())for(const e of n.getAttributeNames())if(e.endsWith(E)){const t=c[s++],i=n.getAttribute(e).split(k),o=/([.?@])?(.*)/.exec(t);r.push({type:1,index:a,name:o[2],strings:i,ctor:\".\"===o[1]?ee:\"?\"===o[1]?te:\"@\"===o[1]?ie:X}),n.removeAttribute(e)}else e.startsWith(k)&&(r.push({type:6,index:a}),n.removeAttribute(e));if(H.test(n.tagName)){const e=n.textContent.split(k),t=e.length-1;if(t>0){n.textContent=A?A.emptyScript:\"\";for(let i=0;i<t;i++)n.append(e[i],N()),q.nextNode(),r.push({type:2,index:++a});n.append(e[t],N())}}}else if(8===n.nodeType)if(n.data===S)r.push({type:2,index:a});else{let e=-1;for(;-1!==(e=n.data.indexOf(k,e+1));)r.push({type:7,index:a}),e+=k.length-1}a++}}static createElement(e,t){const i=I.createElement(\"template\");return i.innerHTML=e,i}}function Q(e,t,i=e,n){if(t===V)return t;let a=void 0!==n?i._$Co?.[n]:i._$Cl;const s=P(t)?void 0:t._$litDirective$;return a?.constructor!==s&&(a?._$AO?.(!1),void 0===s?a=void 0:(a=new s(e),a._$AT(e,i,n)),void 0!==n?(i._$Co??=[])[n]=a:i._$Cl=a),void 0!==a&&(t=Q(e,a._$AS(e,t.values),a,n)),t}class K{constructor(e,t){this._$AV=[],this._$AN=void 0,this._$AD=e,this._$AM=t}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(e){const{el:{content:t},parts:i}=this._$AD,n=(e?.creationScope??I).importNode(t,!0);q.currentNode=n;let a=q.nextNode(),s=0,o=0,r=i[0];for(;void 0!==r;){if(s===r.index){let t;2===r.type?t=new G(a,a.nextSibling,this,e):1===r.type?t=new r.ctor(a,r.name,r.strings,this,e):6===r.type&&(t=new ne(a,this,e)),this._$AV.push(t),r=i[++o]}s!==r?.index&&(a=q.nextNode(),s++)}return q.currentNode=I,n}p(e){let t=0;for(const i of this._$AV)void 0!==i&&(void 0!==i.strings?(i._$AI(e,i,t),t+=i.strings.length-2):i._$AI(e[t])),t++}}class G{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(e,t,i,n){this.type=2,this._$AH=W,this._$AN=void 0,this._$AA=e,this._$AB=t,this._$AM=i,this.options=n,this._$Cv=n?.isConnected??!0}get parentNode(){let e=this._$AA.parentNode;const t=this._$AM;return void 0!==t&&11===e?.nodeType&&(e=t.parentNode),e}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(e,t=this){e=Q(this,e,t),P(e)?e===W||null==e||\"\"===e?(this._$AH!==W&&this._$AR(),this._$AH=W):e!==this._$AH&&e!==V&&this._(e):void 0!==e._$litType$?this.$(e):void 0!==e.nodeType?this.T(e):(e=>T(e)||\"function\"==typeof e?.[Symbol.iterator])(e)?this.k(e):this._(e)}O(e){return this._$AA.parentNode.insertBefore(e,this._$AB)}T(e){this._$AH!==e&&(this._$AR(),this._$AH=this.O(e))}_(e){this._$AH!==W&&P(this._$AH)?this._$AA.nextSibling.data=e:this.T(I.createTextNode(e)),this._$AH=e}$(e){const{values:t,_$litType$:i}=e,n=\"number\"==typeof i?this._$AC(e):(void 0===i.el&&(i.el=Y.createElement(Z(i.h,i.h[0]),this.options)),i);if(this._$AH?._$AD===n)this._$AH.p(t);else{const e=new K(n,this),i=e.u(this.options);e.p(t),this.T(i),this._$AH=e}}_$AC(e){let t=B.get(e.strings);return void 0===t&&B.set(e.strings,t=new Y(e)),t}k(e){T(this._$AH)||(this._$AH=[],this._$AR());const t=this._$AH;let i,n=0;for(const a of e)n===t.length?t.push(i=new G(this.O(N()),this.O(N()),this,this.options)):i=t[n],i._$AI(a),n++;n<t.length&&(this._$AR(i&&i._$AB.nextSibling,n),t.length=n)}_$AR(e=this._$AA.nextSibling,t){for(this._$AP?.(!1,!0,t);e&&e!==this._$AB;){const t=e.nextSibling;e.remove(),e=t}}setConnected(e){void 0===this._$AM&&(this._$Cv=e,this._$AP?.(e))}}class X{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(e,t,i,n,a){this.type=1,this._$AH=W,this._$AN=void 0,this.element=e,this.name=t,this._$AM=n,this.options=a,i.length>2||\"\"!==i[0]||\"\"!==i[1]?(this._$AH=Array(i.length-1).fill(new String),this.strings=i):this._$AH=W}_$AI(e,t=this,i,n){const a=this.strings;let s=!1;if(void 0===a)e=Q(this,e,t,0),s=!P(e)||e!==this._$AH&&e!==V,s&&(this._$AH=e);else{const n=e;let o,r;for(e=a[0],o=0;o<a.length-1;o++)r=Q(this,n[i+o],t,o),r===V&&(r=this._$AH[o]),s||=!P(r)||r!==this._$AH[o],r===W?e=W:e!==W&&(e+=(r??\"\")+a[o+1]),this._$AH[o]=r}s&&!n&&this.j(e)}j(e){e===W?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,e??\"\")}}class ee extends X{constructor(){super(...arguments),this.type=3}j(e){this.element[this.name]=e===W?void 0:e}}class te extends X{constructor(){super(...arguments),this.type=4}j(e){this.element.toggleAttribute(this.name,!!e&&e!==W)}}class ie extends X{constructor(e,t,i,n,a){super(e,t,i,n,a),this.type=5}_$AI(e,t=this){if((e=Q(this,e,t,0)??W)===V)return;const i=this._$AH,n=e===W&&i!==W||e.capture!==i.capture||e.once!==i.once||e.passive!==i.passive,a=e!==W&&(i===W||n);n&&this.element.removeEventListener(this.name,this,i),a&&this.element.addEventListener(this.name,this,e),this._$AH=e}handleEvent(e){\"function\"==typeof this._$AH?this._$AH.call(this.options?.host??this.element,e):this._$AH.handleEvent(e)}}class ne{constructor(e,t,i){this.element=e,this.type=6,this._$AN=void 0,this._$AM=t,this.options=i}get _$AU(){return this._$AM._$AU}_$AI(e){Q(this,e)}}const ae=b.litHtmlPolyfillSupport;ae?.(Y,G),(b.litHtmlVersions??=[]).push(\"3.3.0\");const se=globalThis;\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */class oe extends x{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){const e=super.createRenderRoot();return this.renderOptions.renderBefore??=e.firstChild,e}update(e){const t=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(e),this._$Do=((e,t,i)=>{const n=i?.renderBefore??t;let a=n._$litPart$;if(void 0===a){const e=i?.renderBefore??null;n._$litPart$=a=new G(t.insertBefore(N(),e),e,void 0,i??{})}return a._$AI(e),a})(t,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1)}render(){return V}}oe._$litElement$=!0,oe.finalized=!0,se.litElementHydrateSupport?.({LitElement:oe});const re=se.litElementPolyfillSupport;re?.({LitElement:oe}),(se.litElementVersions??=[]).push(\"4.2.0\");\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst le={attribute:!0,type:String,converter:_,reflect:!1,hasChanged:w},ce=(e=le,t,i)=>{const{kind:n,metadata:a}=i;let s=globalThis.litPropertyMetadata.get(a);if(void 0===s&&globalThis.litPropertyMetadata.set(a,s=new Map),\"setter\"===n&&((e=Object.create(e)).wrapped=!0),s.set(i.name,e),\"accessor\"===n){const{name:n}=i;return{set(i){const a=t.get.call(this);t.set.call(this,i),this.requestUpdate(n,a,e)},init(t){return void 0!==t&&this.C(n,void 0,e,t),t}}}if(\"setter\"===n){const{name:n}=i;return function(i){const a=this[n];t.call(this,i),this.requestUpdate(n,a,e)}}throw Error(\"Unsupported decorator location: \"+n)};\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */function de(e){return(t,i)=>\"object\"==typeof i?ce(e,t,i):((e,t,i)=>{const n=t.hasOwnProperty(i);return t.constructor.createProperty(i,e),n?Object.getOwnPropertyDescriptor(t,i):void 0})(e,t,i)}const he=o`\n  --default-red: 244, 67, 54;\n  --default-pink: 233, 30, 99;\n  --default-purple: 146, 107, 199;\n  --default-deep-purple: 110, 65, 171;\n  --default-indigo: 63, 81, 181;\n  --default-blue: 33, 150, 243;\n  --default-light-blue: 3, 169, 244;\n  --default-cyan: 0, 188, 212;\n  --default-teal: 0, 150, 136;\n  --default-green: 76, 175, 80;\n  --default-light-green: 139, 195, 74;\n  --default-lime: 205, 220, 57;\n  --default-yellow: 255, 235, 59;\n  --default-amber: 255, 193, 7;\n  --default-orange: 255, 152, 0;\n  --default-deep-orange: 255, 111, 34;\n  --default-brown: 121, 85, 72;\n  --default-light-grey: 189, 189, 189;\n  --default-grey: 158, 158, 158;\n  --default-dark-grey: 96, 96, 96;\n  --default-blue-grey: 96, 125, 139;\n  --default-black: 0, 0, 0;\n  --default-white: 255, 255, 255;\n  --default-disabled: 189, 189, 189;\n`,ue=o`\n  --default-disabled: 111, 111, 111;\n`,pe=\"%c WEATHER-CONDITION-CARD %c 2.0.0\",me=\"/local/community/ha-card-weather-conditions/icons\",ge=\"/local/ha-card-weather-conditions/icons\",ye=\"color: white; background: green; font-weight: 700;\",fe=\"color: green; background: white; font-weight: 700;\",ve=\"color: black; background: white; font-weight: 700;\",_e={en:0,it:1,nl:2,es:3,de:4,fr:5,\"sr-latn\":6,pt:7,da:8,\"no-no\":9,cs:10,ru:11},we={snowy:\"snowy-3\",\"light-snow\":\"snowy-2\",\"snowy-rainy\":\"snowy-1\",\"partlycloudy-light-snow\":\"snowy-1\",\"partlycloudy-snow\":\"snowy-1\",\"partlycloudy-light-rain\":\"rainy-1\",\"light-rain\":\"rainy-1\",rainy:\"rainy-2\",\"partlycloudy-rain\":\"rainy-1\",\"partlycloudy-fog\":\"fog\",cloudy:\"cloudy-original\",partlycloudy:\"cloudy-day-2\",\"partlycloudy-lightning\":\"cloudy-day-1\",lightning:\"cloudy-day-1\",clear:\"day\"},$e={...we},xe={freezing_rain_heavy:\"rainy-3\",\"heavy freezing rain\":\"rainy-3\",freezing_rain:\"rainy-2\",\"freezing rain\":\"rainy-2\",freezing_rain_light:\"rainy-1\",\"light freezing rain\":\"rainy-1\",freezing_drizzle:\"rain-and-sleet-mix\",\"freezing drizzle\":\"rain-and-sleet-mix\",ice_pellets_heavy:\"rain-and-snow-mix\",\"heavy ice pellets\":\"rain-and-snow-mix\",ice_pellets:\"rain-and-snow-mix\",\"ice pellets\":\"rain-and-snow-mix\",ice_pellets_light:\"rain-and-snow-mix\",\"light ice pellets\":\"rain-and-snow-mix\",snow_heavy:\"snowy-3\",\"heavy snow\":\"snowy-3\",snow:\"snowy-2\",snow_light:\"snowy-1\",\"light snow\":\"snowy-1\",flurries:\"wind\",tstorm:\"tropical-storm\",rain_heavy:\"rainy-3\",\"heavy rain\":\"rainy-3\",rain_light:\"rainy-1\",\"light rain\":\"rainy-1\",rain:\"rainy-2\",drizzle:\"rainy-1\",fog_light:\"haze\",\"light fog\":\"haze\",fog:\"fog\",cloudy:\"cloudy-original\",mostly_cloudy:\"cloudy-day-3\",\"mostly cloudy\":\"cloudy-day-3\",partly_cloudy:\"cloudy-day-2\",\"partly cloudy\":\"cloudy-day-2\",mostly_clear:\"cloudy-day-1\",\"mostly clear\":\"cloudy-day-1\",clear:\"day\"},be={...xe,freezing_rain_heavy:\"rainy-6\",\"heavy freezing rain\":\"rainy-6\",freezing_rain:\"rainy-5\",\"freezing rain\":\"rainy-5\",freezing_rain_light:\"rainy-4\",\"light freezing rain\":\"rainy-4\",snow_heavy:\"snowy-6\",\"heavy snow\":\"snowy-6\",snow:\"snowy-5\",snow_light:\"snowy-4\",\"light snow\":\"snowy-4\",rain_heavy:\"rainy-6\",\"heavy rain\":\"rainy-6\",rain_light:\"rainy-4\",\"light rain\":\"rainy-4\",rain:\"rainy-5\",drizzle:\"rainy-4\",mostly_cloudy:\"cloudy-night-3\",\"mostly cloudy\":\"cloudy-night-3\",partly_cloudy:\"cloudy-night-2\",\"partly cloudy\":\"cloudy-night-2\",mostly_clear:\"cloudy-night-1\",\"mostly clear\":\"cloudy-night-1\",clear:\"night\",sunny:\"night\"},Ae={clear:\"day\",\"clear-day\":\"day\",rain:\"rainy-2\",snow:\"snowy-2\",sleet:\"rain-and-sleet-mix\",wind:\"cloudy-day-1\",fog:\"fog\",cloudy:\"cloudy-original\",\"partly-cloudy-day\":\"cloudy-day-2\"},ze={...Ae,clear:\"night\",\"clear-night\":\"night\",wind:\"cloudy-night-1\",\"partly-cloudy-day\":\"cloudy-night-2\",\"partly-cloudy-night\":\"cloudy-night-2\"},Ee={cloudy:\"cloudy-day-3\",exceptional:\"severe-thunderstorm\",fog:\"fog\",hail:\"snow-and-sleet-mix\",lightning:\"severe-thunderstorm\",\"lightning-rainy\":\"scattered-thunderstorms\",partlycloudy:\"cloudy-day-3\",pouring:\"rainy-6\",rainy:\"rainy-5\",snowy:\"snowy-6\",\"snowy-rainy\":\"snow-and-sleet-mix\",sunny:\"clear-day\",windy:\"wind\",\"windy-variant\":\"wind\"},ke={...Ee,\"clear-night\":\"clear-night\"},Se={\"clear sky\":\"day\",\"few clouds\":\"cloudy-day-1\",\"scattered clouds\":\"cloudy-day-2\",\"broken clouds\":\"cloudy-day-3\",\"shower rain\":\"rainy-3\",rain:\"rainy-2\",thunderstorm:\"tropical-storm\",snow:\"snowy-2\",mist:\"fog\"},Ce={...Se,\"clear sky\":\"day-night\",\"few clouds\":\"cloudy-night-1\",\"scattered clouds\":\"cloudy-night-2\",\"broken clouds\":\"cloudy-night-3\"},Ie={freezing_rain_heavy:\"rainy-3\",\"heavy freezing rain\":\"rainy-3\",freezing_rain:\"rainy-2\",\"freezing rain\":\"rainy-2\",freezing_rain_light:\"rainy-1\",\"light freezing rain\":\"rainy-1\",freezing_drizzle:\"rain-and-sleet-mix\",sleet:\"rain-and-sleet-mix\",\"freezing drizzle\":\"rain-and-sleet-mix\",ice_pellets_heavy:\"rain-and-snow-mix\",\"heavy ice pellets\":\"rain-and-snow-mix\",ice_pellets:\"rain-and-snow-mix\",\"ice pellets\":\"rain-and-snow-mix\",ice_pellets_light:\"rain-and-snow-mix\",\"light ice pellets\":\"rain-and-snow-mix\",snow_heavy:\"snowy-3\",\"heavy snow\":\"snowy-3\",snow:\"snowy-2\",snow_light:\"snowy-1\",\"light snow\":\"snowy-1\",flurries:\"wind\",tstorm:\"tropical-storm\",rain_heavy:\"rainy-3\",\"heavy rain\":\"rainy-3\",rain_light:\"rainy-1\",rainy:\"rainy-1\",\"light rain\":\"rainy-1\",rain:\"rainy-2\",drizzle:\"rainy-1\",fog_light:\"haze\",\"light fog\":\"haze\",fog:\"fog\",cloudy:\"cloudy-original\",mostly_cloudy:\"cloudy-day-3\",\"mostly cloudy\":\"cloudy-day-3\",partly_cloudy:\"cloudy-day-2\",partlycloudy:\"cloudy-day-2\",\"partly-cloudy-day\":\"cloudy-day-2\",\"partly cloudy\":\"cloudy-day-2\",mostly_clear:\"cloudy-day-1\",\"mostly clear\":\"cloudy-day-1\",clear:\"day\",\"clear-day\":\"day\",wind:\"wind\",windy:\"wind\",sunny:\"day\",\"clear-night\":\"day\"},Ne={...Ie,freezing_rain_heavy:\"rainy-6\",\"heavy freezing rain\":\"rainy-6\",freezing_rain:\"rainy-5\",\"freezing rain\":\"rainy-5\",freezing_rain_light:\"rainy-4\",\"light freezing rain\":\"rainy-4\",snow_heavy:\"snowy-6\",\"heavy snow\":\"snowy-6\",snow:\"snowy-5\",snow_light:\"snowy-4\",\"light snow\":\"snowy-4\",rain_heavy:\"rainy-6\",\"heavy rain\":\"rainy-6\",rain_light:\"rainy-4\",\"light rain\":\"rainy-4\",rain:\"rainy-5\",drizzle:\"rainy-4\",mostly_cloudy:\"cloudy-night-3\",\"mostly cloudy\":\"cloudy-night-3\",partly_cloudy:\"cloudy-night-2\",partlycloudy:\"cloudy-night-2\",\"partly-cloudy-night\":\"cloudy-night-2\",\"partly cloudy\":\"cloudy-night-2\",mostly_clear:\"cloudy-night-1\",\"mostly clear\":\"cloudy-night-1\",clear:\"night\",\"clear-night\":\"night\",sunny:\"night\"},Pe={pirateweather:{iconsDay:Ie,iconsNight:Ne},climacell:{iconsDay:xe,iconsNight:be},darksky:{iconsDay:Ae,iconsNight:ze},openweathermap:{iconsDay:Se,iconsNight:Ce},buienradar:{iconsDay:we,iconsNight:$e},defaulthass:{iconsDay:Ee,iconsNight:ke}},Te=(e,t)=>{const i=Object.keys(t).find((t=>t.toLowerCase()===e.toLowerCase()));return i?t[i]:e},Ue=e=>{const t={en:0,it:1,nl:2,es:3,de:4,fr:5,\"sr-latn\":6,pt:7,da:8,\"no-no\":9,cs:10,ru:11};return{locale:{en:\"en-US\",it:\"it-IT\",nl:\"nl-NL\",es:\"es-ES\",de:\"de-DE\",fr:\"fr-FR\",\"sr-latn\":\"sr-Latn\",pt:\"pt-PT\",da:\"da-DK\",\"no-no\":\"nb-NO\",cs:\"cs-CZ\",ru:\"ru-RU\"}[e]||e,timezone:{en:\"America/New_York\",it:\"Europe/Rome\",nl:\"Europe/Amsterdam\",es:\"Europe/Madrid\",de:\"Europe/Berlin\",fr:\"Europe/Paris\",\"sr-latn\":\"Europe/Belgrade\",ja:\"Asia/Tokyo\",pt:\"Europe/Lisbon\",da:\"Europe/Copenhagen\",\"no-no\":\"Europe/Oslo\",cs:\"Europe/Prague\",ru:\"Europe/Moscow\"}[e]||\"UTC\",...e in t&&{cwc:t[e]}}},De=e=>({it:\"it-IT\",en:\"en-US\",fr:\"fr-FR\",de:\"de-DE\",es:\"es-ES\",ja:\"ja-JP\",zh:\"zh-CN\"}[e]||`${e}-${e.toUpperCase()}`),Oe=({stringNumber:e,lang:t=\"en\",fractionDigits:i=1,useGrouping:n=!1})=>{const a=parseFloat(e);if(Number.isNaN(a))return\"\";const s=((e=\"en-US\",t=1,i=!1)=>new Intl.NumberFormat(e,{minimumFractionDigits:t,maximumFractionDigits:t,useGrouping:i}))(De(t),i,n);return s.format(a)};const Me=(e,t)=>t&&e.states[t]?.state,Le=(e,t,i)=>t&&e.states[t]?.attributes[i],je=({entityId:e,hass:t,lang:i=\"en\",decimals:n=0}={})=>{const a=t&&e&&t.states[e]?.state;return void 0!==a?Oe({stringNumber:a,fractionDigits:n,lang:i}):void 0},Re=(e,t)=>t&&e.states[t]?.attributes?.unit_of_measurement,He=(e,t)=>t&&e.states[t]?.attributes?.icon,Fe=(e,t)=>{const i=\"number\"==typeof e?e:parseFloat(e);if(Number.isNaN(i))return t[e]??null;if(i<0||i>360)return console.error(`Invalid wind direction: '${e}'. Valid values are between 0 and 360 degrees.`),null;return t[[\"N\",\"NNE\",\"NE\",\"ENE\",\"E\",\"ESE\",\"SE\",\"SSE\",\"S\",\"SSW\",\"SW\",\"WSW\",\"W\",\"WNW\",\"NW\",\"NNW\"][Math.floor((i+11.25)%360/22.5)]]??null};function Ve(e,t=5e3){return new Promise((i=>{const n=new Image,a=setTimeout((()=>{n.src=\"\",i(!1)}),t);n.onload=()=>{clearTimeout(a),i(!0)},n.onerror=()=>{clearTimeout(a),i(!1)},n.src=e}))}function We(e,...t){console.info(e,...t.length?t:[])}function Be(e,t=\"en-US\"){if(\"number\"==typeof e)return e;const i=e.replace(/\\./g,\"\").replace(\",\",\".\");return Number(i)}const qe={new_moon:\"🌑\",new:\"🌑\",waxing_crescent:\"🌒\",first_quarter:\"🌓\",waxing_gibbous:\"🌔\",full:\"🌕\",full_moon:\"🌕\",waning_gibbous:\"🌖\",third_quarter:\"🌗\",last_quarter:\"🌗\",waning_crescent:\"🌘\"},Ze=o`\n  ha-card {\n    cursor: pointer;\n    position: relative;\n    width: 100%;\n  }\n\n  .ha-card-weather-conditions {\n    width: 100%;\n    box-sizing: border-box;\n    background-color: var(--card-background-color, #1c1c1c);\n    color: var(--primary-text-color, #ffffff);\n    border-radius: var(--ha-card-border-radius, 12px);\n    box-shadow: var(--ha-card-box-shadow, 0 2px 6px rgba(0, 0, 0, 0.2));\n    overflow: hidden;\n    padding: 0;\n    display: flex;\n    flex-direction: column;\n  }\n\n  .nd-container {\n    width: 100%;\n    box-sizing: border-box;\n    display: flex;\n    flex-direction: column;\n    padding: 16px 20px; /* ← padding orizzontale più ampio */\n    gap: 12px;\n    background-size: cover;\n    background-position: center;\n    transition: background-image 0.3s ease-in-out;\n  }\n\n  /* Esempio di stile dinamico aggiuntivo se habgImage è una classe */\n  .nd-container.sunny {\n    background-image: url('/local/images/sunny-bg.jpg');\n  }\n\n  .nd-container.rainy {\n    background-image: url('/local/images/rainy-bg.jpg');\n  }\n\n  /* -------------- */\n\n`,Je=o`\n\n.summary-grid-container {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: 1fr 1fr 1fr; /* <-- 3 colonne reali */\n  grid-template-rows: auto auto;\n  width: 100%;\n  max-width: 600px;\n  // background: #1c1c1c;\n  // color: white;\n  gap: 4px;\n  padding: 0px;\n  box-sizing: border-box;\n  // border: 1px solid #444; /* debug */\n}\n\n.summary-col-left {\n  grid-column: 1;\n  grid-row: 1 / span 2;\n  // background: #2c2c2c;\n  padding-top: 0px;\n  padding-right: 0px;\n  padding-bottom: 0px;\n  padding-left: 0px;\n  \n  display: flex;                 /* Attiva Flexbox */\n  justify-content: center;      /* Centra orizzontalmente */\n  align-items: center;          /* Centra verticalmente */\n\n  width: 100%;\n  max-width: 100%;\n  aspect-ratio: 1 / 1; /* opzionale: mantiene forma quadrata */\n  overflow: hidden;\n}\n\n.summary-top-right {\n  grid-column: 2 / span 2; /* occupa colonne 2 e 3 */\n  grid-row: 1;\n  // background: #3c3c3c;\n  padding-top: 0px;\n  padding-right: 8px;\n  padding-bottom: 0px;\n  padding-left: 8px;\n  display: flex;            /* aggiunto */\n  align-items: center;      /* centra verticalmente */\n  justify-content: flex-start; /* allinea a sinistra */\n}\n\n.summary-bottom-right-left {\n  grid-column: 2;\n  grid-row: 2;\n  // background: #4c4c4c;\n  padding-top: 0px;\n  padding-right: 8px;\n  padding-bottom: 0px;\n  padding-left: 8px;\n\n  display: flex;                 /* Attiva Flexbox */\n  justify-content: center;      /* Centra orizzontalmente */\n  align-items: center;          /* Centra verticalmente */\n}\n\n.summary-bottom-right-right {\n  grid-column: 3;\n  grid-row: 2;\n  // background: #5c5c5c;\n  padding-top: 0px;\n  padding-right: 8px;\n  padding-bottom: 0px;\n  padding-left: 8px;\n}\n\n.weather-condition-icon {\n  width: 100%;\n  height: auto;\n  max-width: 100%;\n  max-height: 100%;\n  object-fit: contain;\n  // max-width: 100%;\n  // max-height: 100%;\n  // width: 72px;\n  // height: 72px;\n  // object-fit: contain;\n\n  transition: transform 0.2s ease;\n}\n  \n.summary-col-left:hover .weather-condition-icon {\n  transform: scale(1.05);\n}\n\n.weather-city-name {\n  font-size: clamp(1em, 2vw, 1.2em);\n  text-align: left;\n}\n\n.moon-row {\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  // font-size: 0.95em;\n  // color: #eeeeee;\n}\n\n.summary-moon-icon {\n  font-size: 1.8em;\n  display: inline-block;\n}\n\n.temperature-block {\n  display: flex;\n  flex-direction: column;\n  align-items: flex-end;\n  text-align: right;\n}\n\n.temperature {\n  font-size: 1.6em;\n  font-weight: bold;\n}\n\n.temp-unit {\n  font-size: 0.95em;\n  vertical-align: super;\n  margin-left: 2px;\n}\n\n.feels-like {\n  font-size: 0.85em;\n  // color: #aaaaaa;\n}\n\n.summary-wrapper {\n  position: relative;\n  width: 100%;\n  height: 100%;\n  min-height: 100px; /* oppure clamp() dinamico */\n  overflow: visible;\n}\n\n.lightning-background {\n  position: absolute;\n  inset: 0; /* top: 0; right: 0; bottom: 0; left: 0 */\n  pointer-events: none;\n  z-index: 0;\n}\n\n.lightning-flash {\n  position: absolute;\n  width: 2px;\n  background: white;\n  opacity: 0.7;\n  transform: translate(-50%, -50%);\n  animation-name: flash-blink;\n  animation-timing-function: ease-in-out;\n  animation-iteration-count: infinite;\n  border-radius: 1px;\n  filter: blur(0.5px);\n  box-shadow: 0 0 4px rgba(255,255,255,0.6);\n\n  z-index: 0;\n}\n\n@keyframes flash-blink {\n  0%, 100% {\n    opacity: 0.1;\n  }\n  50% {\n    opacity: 0.9;\n  }\n}\n\n.lightning-flash-zigzag {\n  position: absolute;\n  width: 2px;\n  height: 0;\n  background: linear-gradient(to bottom, yellow, white);\n  clip-path: polygon(var(--points));\n  animation: flash-zigzag linear forwards;\n  z-index: 3;\n}\n\n@keyframes flash-zigzag {\n  0% {\n    opacity: 1;\n    transform: scaleY(1);\n  }\n  100% {\n    opacity: 0;\n    transform: scaleY(1.2);\n  }\n}\n\n.lightning-svg {\n  position: absolute;\n  transform: translate(-50%, 0);\n  opacity: 0;\n  filter: drop-shadow(0 0 4px rgba(98, 61, 173, 0.6));\n  animation-name: flash-zigzag-svg;\n  animation-timing-function: ease-in-out;\n  animation-iteration-count: 1;\n  z-index: 3;\n}\n\n@keyframes flash-zigzag-svg {\n  0%, 100% {\n    opacity: 0;\n  }\n  40% {\n    opacity: 1;\n  }\n  60% {\n    opacity: 0.5;\n  }\n}\n`,Ye=o`\n.present-grid-container {\n  display: flex;\n  flex-direction: column;\n  gap: 4px;\n}\n\n.present-row {\n  display: flex;\n  justify-content: space-between;\n  gap: 16px;\n}\n\n.present-left,\n.present-right {\n  flex: 1;\n}\n\n.present-left {\n  display: flex;\n  justify-content: flex-start;\n}\n\n.present-right {\n  display: flex;\n  justify-content: flex-end;\n}\n\n.present-value-block {\n  display: flex;\n  align-items: center;\n  gap: 4px;\n}\n\n.present-unit {\n  font-size: 0.9em;\n  opacity: 0.8;\n}\n`,Qe=o`\n.ultraviolet-grid-container {\n  display: flex;\n  flex-direction: column;\n  gap: 4px;\n}\n\n.ultraviolet-row {\n  display: flex;\n  justify-content: space-between;\n  gap: 16px;\n}\n\n.ultraviolet-left,\n.present-right {\n  flex: 1;\n}\n\n.ultraviolet-left {\n  display: flex;\n  justify-content: flex-start;\n}\n\n.ultraviolet-right {\n  display: flex;\n  justify-content: flex-end;\n}\n\n.ultraviolet-value-block {\n  display: flex;\n  align-items: center;\n  gap: 4px;\n}\n\n.ultraviolet-unit {\n  font-size: 0.9em;\n  opacity: 0.8;\n}\n\n------------------------------------------------------------------\n\n// .ultraviolet-grid-container {\n//   display: flex;\n//   flex-direction: column;\n//   gap: 12px;\n// }\n\n// .ultraviolet-row {\n//   display: flex;\n//   justify-content: space-between;\n//   padding: 4px 0;\n// }\n\n// .ultraviolet-value-block {\n//   display: flex;\n//   align-items: center;\n//   gap: 4px;\n// }\n\n// .ultraviolet-unit {\n//   font-size: 0.9em;\n//   opacity: 0.7;\n// }\n\n.ultraviolet-skin-type-grid {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(48px, 1fr));\n  gap: 8px;\n  margin-top: 8px;\n}\n\n.ultraviolet-skin-type-cell {\n  flex: 1;\n  min-width: 48px;\n  height: 48px;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  border-radius: 6px;\n  font-family: 'Segoe UI', sans-serif;\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n  color: black;\n}\n\n.ultraviolet-skin-type-label {\n  font-weight: bold;\n  font-size: 0.95em;\n  line-height: 1em;\n}\n\n.ultraviolet-exposure-time {\n  font-size: 0.75em;\n  margin-top: 2px;\n  color: #222;\n  opacity: 0.85;\n}\n\n\n\n\n\n\n`,Ke=o`\n.pollen-grid-container {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(48px, 1fr));\n  gap: 8px 12px;\n  width: 100%;\n  justify-items: center;\n  align-items: end;\n  padding: 8px 4px;\n  box-sizing: border-box;\n}\n\n\n.pollen-stack {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  gap: 4px;\n  min-width: 48px;\n}\n\n\n  .levels {\n    display: flex;\n    flex-direction: column-reverse;\n    gap: clamp(1px, 0.2vw, 2px);\n  }\n\n  .level {\n    width: clamp(16px, 3.5vw, 24px);\n    height: clamp(5px, 0.7vw, 8px);     /* 👈 anche in altezza */\n    border-radius: 3px;\n    opacity: 0.3;\n    transition: opacity 0.2s ease;\n  }\n\n  .level.active {\n    opacity: 1;\n    outline: 1px solid #333;\n  }\n\n  .molto-alto {\n    background-color: #f44336;\n  }\n\n  .alto {\n    background-color: #ff9800;\n  }\n\n  .moderato {\n    background-color: #ffeb3b;\n  }\n\n  .basso {\n    background-color: #4caf50;\n  }\n\n  .pollen-name {\n    font-size: clamp(0.55em, 1.3vw, 0.85em); /* 👈 stringe di più */\n    // font-weight: 500;\n    text-align: center;\n    // color: #333;\n    white-space: nowrap;\n  }\n\n  .label {\n    width: 100%;\n    text-align: center;\n    font-size: clamp(0.55em, 1.3vw, 0.85em);\n    // font-weight: 500;\n    margin-top: clamp(4px, 0.5vw, 8px);\n  }\n`,Ge=o`\n  .camera-container {\n    margin-top: 10px;\n    width: 100%;\n    display: flex;\n    align-items: stretch;\n  }\n\n  .camera-image {\n    aspect-ratio: 16 / 9;\n    width: 100%;\n    position: relative;\n    overflow: hidden;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n  }\n\n  .camera-image > img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`,Xe=o`\n\n.weather-forecast-grid-container {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(78px, 1fr));\n  column-gap: 2px; /* spazio orizzontale tra i giorni */\n  row-gap: 6px;    /* spazio verticale tra righe, se ci sono */\n  align-items: stretch;\n  font-family: 'Segoe UI', sans-serif;\n  width: 100%;\n}\n  \n.weather-forecast-grid-wrapper {\n  display: flex;\n  flex-direction: column;\n  align-items: center; /* centrare il titolo orizzontalmente */\n}\n\n.weather-forecast-title {\n  font-size: clamp(0.85em, 1vw, 0.95em);\n  font-weight: bold;\n  // margin-bottom: 0.5em;\n  text-align: center;\n}\n\n.weather-forecast-slot {\n  text-align: center;\n  padding: 8px 4px;\n  min-width: 0;\n  overflow: hidden;\n}\n\n.weather-forecast-slot:last-child {\n  border-right: none;\n}\n\n.weather-forecast-label-slot {\n  font-size: 0.9em;\n  font-weight: bold;\n  margin-bottom: 6px; /* ridotto */\n}\n\n.weather-forecast-icon {\n  font-size: 1.6rem; /* ridotto */\n  /* margin: 6px 0; ridotto */\n  height: 32px;\n}\n\n.weather-forecast-temperature {\n  font-size: clamp(0.8em, 1vw, 0.9em); /* leggermente più piccolo */\n  margin: 4px 0; /* meno margine */\n}\n\n.weather-forecast-temperature .high {\n  font-weight: bold;\n}\n\n.weather-forecast-precipitation {\n  font-size: clamp(0.65em, 1vw, 0.75em);\n  line-height: 1.2; /* compatta verticalmente */\n}\n\n.weather-forecast-precipitation .mm {\n  font-weight: bold;\n}\n`,et=o`\n.meteodcpalarm-grid-container {\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: center;\n  gap: 16px;\n  padding: 12px;\n}\n\n.meteodcpalarm-group {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  flex: 1 1 72px;     /* 👈 cresce, ma non scende sotto i 72px */\n  max-width: 220px;   /* 👈 opzionale: previene allargamento eccessivo */\n  text-align: center;\n}\n\n.meteodcpalarm-group ha-icon {\n  --mdc-icon-size: 36px;\n}\n\n.meteodcpalarm-label {\n  margin-top: 6px;\n  font-size: 0.85em;\n  color: var(--primary-text-color);\n}\n\n\n`,tt=(e,t,i)=>{const n=\"below_horizon\"===i,a=(n?t.iconsNight:t.iconsDay)[e];return t.path||console.info(\"Image path not found.\"),a?`${t.path}/${t.iconType}/${a}.svg`:(console.info(`Icons issue. Model=${t.icons_model}, Time=${n?\"night\":\"day\"}, Condition=${e}`),\"\")};function it(e){return!!e&&e.themes.darkMode}async function nt(){const[e,t]=await Promise.all([Ve(`${me}/static/cloudy.svg`),Ve(`${ge}/static/cloudy.svg`)]);let i=null;if(i=e?me:t?ge:null,!i)return We(`${pe} - Impossibile determinare il path immagini.`),{translations:[],imagePath:null};const n=`${i}/../transl/`;return{translations:await Promise.all([\"en\",\"it\",\"nl\",\"es\",\"de\",\"fr\",\"sr-latn\",\"pt\",\"da\",\"no-NO\",\"cs\"].map((e=>async function(e){try{const t=await fetch(e);if(!t.ok){const i=`ERROR retrieving JSON file: '${e}', status: ${t.status} ${t.statusText}`;throw console.info(i),new Error(i)}return console.info(`Locale '${e}' loaded`),await t.text()}catch(t){throw console.info(`Fetch failed for '${e}':`,t),t}}(`${n}${e}.json`)))),imagePath:i}}class at extends oe{constructor(){super(...arguments),this.isPanel=!1,this.editMode=!1,this.invalidConfig=!1,this._hasPresent=!1,this._hasDailyForecasts=!1,this._hasHourlyForecasts=!1,this._hasMarineDailyForecasts=!1,this._hasMarineHourlyForecasts=!1,this._hasMetealarm=!1,this._hasDPCalarm=!1,this._hasMeteogram=!1,this._hasAirQuality=!1,this._hasPollen=!1,this._hasUltraviolet=!1,this._hasAlert=!1,this._hasSea=!1,this._hasCamera=!1}updated(e){if(super.updated(e),e.has(\"hass\")&&this.hass){const t=it(e.get(\"hass\")),i=it(this.hass);t!==i&&this.toggleAttribute(\"dark-mode\",i)}}static get styles(){return[o`\n        :host {\n          ${he}\n        }\n        :host([dark-mode]) {\n          ${ue}\n        }\n        ${o`\n${Ze}\n${Je}\n${Ye}\n${Xe}\n${Qe}\n${Ke}\n${Ge}\n${et}\n`}\n      `]}async setConfig(e){if(!e)throw this.invalidConfig=!0,new Error(\"Invalid configuration\");if(!this._translations?.length||!this._imagesPath){const{translations:e,imagePath:t}=await nt();this._translations=e,this._imagesPath=t}this._name=e?.weather?.name??void 0,this._language=e.language?.toLowerCase()||\"en\",this._loadTranslations(this._language),this._detectDataSections(e),this._setupIcons(e.weather?.icons_model),this._config=e,We(`${pe} - Config loaded.`)}getCardSize(){return 1}_loadTranslations(e){try{const t=JSON.parse(this._translations[_e[e]]);this._terms={windDirections:t.cwcLocWindDirections,words:t.cwcTerms},We(`${pe}%c card \"${this._name}\", locale is '${e}'.`,ye,fe,ve)}catch(t){const i=\"en\",n=JSON.parse(this._translations[_e[i]]);this._terms={windDirections:n.cwcLocWindDirections,words:n.cwcTerms},We(`${pe}%c card \"${this._name}\" unable to use '${e}' locale, set as default '${i}'.`,ye,fe,ve)}}_detectDataSections(e){this._hasPresent=!!e.weather?.present,this._hasDailyForecasts=!!e.weather?.daily_forecasts,this._hasHourlyForecasts=!!e.weather?.hourly_forecasts,this._hasMarineDailyForecasts=!!e.weather?.marine_daily_forecasts,this._hasMarineHourlyForecasts=!!e.weather?.marine_hourly_forecasts,this._hasMetealarm=!!e.weather?.meteoalarm,this._hasDPCalarm=!!e.weather?.dpcalarm,this._hasAirQuality=!!e.airquality,this._hasPollen=e.pollen&&Array.isArray(e.pollen.entities)&&e.pollen.entities.length>0,this._hasUltraviolet=!!e.ultraviolet,this._hasCamera=!!e.camera}_setupIcons(e){if(this._iconsConfig={path:this._imagesPath,iconType:this._config?.weather?.animation?\"animated\":\"static\",icons_model:e||\"pirateweather\",iconsDay:Ie,iconsNight:Ne},e){const t=(e=>{const t=e.toLowerCase()??\"climacell\";if(t in Pe){const{iconsDay:e,iconsNight:i}=Pe[t];return{iconsModel:t,iconsDay:e,iconsNight:i}}console.warn(`Unknown icons model: ${t}. Falling back to 'climacell'.`);const i=Pe.climacell;return{iconsModel:\"climacell\",iconsDay:i.iconsDay,iconsNight:i.iconsNight}})(e);this._iconsConfig.icons_model=t.iconsModel,this._iconsConfig.iconsDay=t.iconsDay,this._iconsConfig.iconsNight=t.iconsNight}}render(){return this.invalidConfig?F`\n        <ha-card class=\"ha-card-weather-conditions\">\n            <div class='banner'>\n                <div class=\"header\">ha-card-weather-conditions</div>\n            </div>\n            <div class='content'>\n                Configuration ERROR!\n            </div>\n        </ha-card>\n    `:this._render()}}e([de({attribute:!1})],at.prototype,\"hass\",void 0),e([de({attribute:!1})],at.prototype,\"_config\",void 0);const st=(e,t,i,n,a,s,o,r)=>{const l=Me(e,r),c=l?qe[l.toLowerCase()]:\"\";const d=Me(e,o),h=Me(e,s.condition)?.toLowerCase()||\"na\",u=s.temperature?je({entityId:s.temperature,hass:e,lang:t})??void 0:void 0,p=s.temperature_feelslike?je({entityId:s.temperature_feelslike,hass:e,lang:t})??void 0:void 0,m=e.states[s.temperature_feelslike]?.attributes.icon??\"\";return(({title:e,moonText:t,moonIcon:i,conditionText:n,conditionIcon:a,temperature:s,temperatureUnit:o,feelsLikeTerm:r,temperatureFeelsLike:l,temperatureFeelsLikeIcon:c})=>a||t||s?F`\n    <div class=\"summary-wrapper\">\n      ${W}\n      <div class=\"summary-grid-container\">\n        ${a?F`\n          <div class=\"summary-col-left\">\n            <img class=\"weather-condition-icon\" src=\"${a}\" alt=\"${n}\" />\n          </div>\n        `:W}\n        ${e?F`\n          <div class=\"summary-top-right\">\n            <span class=\"weather-city-name\">${e}</span>\n          </div>    \n        `:W}\n        ${t?F`\n          <div class=\"summary-bottom-right-left\">\n            <div class=\"moon-row\">\n              <span class=\"summary-moon-icon\">${i}</span>\n              <span class=\"summary-moon-text\">${t}</span>\n            </div>  \n          </div>   \n        `:W}\n        ${s?F`\n          <div class=\"summary-bottom-right-right\">\n            <div class=\"temperature-block\">\n              <div>\n                <span class=\"temperature\">${s}</span>\n                <span class=\"temp-unit\">${o}</span>\n              </div>\n              ${l&&F`<div class=\"feels-like\">${r} <div>${l} ${o}</div></div>`}\n            </div>  \n          </div>\n          `:W}\n      </div>\n    </div>\n    `:F``)({title:a??void 0,moonText:r?Te(l,i.words):void 0,moonIcon:c,conditionText:h,conditionIcon:tt(h,n,d),temperature:u,temperatureUnit:Re(e,s.temperature),feelsLikeTerm:Te(\"Feels Like\",i.words),temperatureFeelsLike:p,temperatureFeelsLikeIcon:m})},ot=e=>\"string\"==typeof e||\"number\"==typeof e,rt=(e,t)=>{const i=[],n=e.precipitationIntensity?.value,a=e.precipitationProbability?.value;if(ot(n)&&ot(a)){const s=De(t),o=Be(n,s),r=Be(a,s);!Number.isNaN(Number(o))&&!Number.isNaN(Number(r))&&o>0&&r>0&&i.push({icon:e.precipitationIntensity.icon||e.precipitationProbability.icon||\"mdi:weather-rainy\",value:`${e.precipitationIntensity.value} ${e.precipitationIntensity.unit} / ${e.precipitationProbability.value} ${e.precipitationProbability.unit}`})}void 0!==e.temperatureLow?.value&&void 0!==e.temperatureHigh?.value&&i.push({icon:e.temperatureLow.icon||e.temperatureHigh.icon||\"mdi:thermometer\",value:`${e.temperatureLow.value} / ${e.temperatureHigh.value}`,unit:e.temperatureLow.unit||e.temperatureHigh.unit});return[\"humidity\",\"pressure\",\"visibility\"].forEach((t=>{return n=e[t],void(void 0!==n?.value&&i.push(n));var n})),void 0===e.windSpeed?.value&&void 0===e.windBearing?.value||i.push({icon:e.windSpeed?.icon||\"mdi:weather-windy\",value:`${e.windBearing?.value?`${e.windBearing.value} `:\"\"}${e.windSpeed?.value??\"\"}`,unit:e.windSpeed?.unit?`${e.windSpeed.unit}`:\"\"}),[\"nextRising\",\"nextSetting\"].forEach((t=>{const n=e[t];n?.value&&i.push({icon:n.icon,value:n.value,unit:\"\"})})),i},lt=(e,t)=>{const i=[];return[\"epa_aqi\",\"epa_primary_pollutant\",\"pm25\",\"pm10\",\"o3\",\"no2\",\"co\",\"so2\"].forEach((t=>{return n=e[t],void(void 0!==n?.value&&i.push(n));var n})),i},ct=(e,t)=>{const i=[],n=e=>F`\n    <span class=\"present-value-block\">\n      ${e.value}${e.unit?F`<span class=\"present-unit\">${e.unit}</span>`:\"\"}\n      <ha-icon icon=\"${e.icon}\" style=${e.icon_color?`color: ${e.icon_color}`:\"\"}></ha-icon>\n    </span>\n  `;i.push(...rt(e,t),...lt(e));const a=[];for(let e=0;e<i.length;e+=2){const t=i[e],o=i[e+1];(t&&t.value||o&&o.value)&&a.push(F`\n        <div class=\"present-row\">\n          <div class=\"present-left\">${t?(s=t,F`\n    <span class=\"present-value-block\">\n      <ha-icon icon=\"${s.icon}\" style=${s.icon_color?`color: ${s.icon_color}`:\"\"}></ha-icon>\n      ${s.value}${s.unit?F`<span class=\"present-unit\">${s.unit}</span>`:\"\"}\n    </span>\n  `):F``}</div>\n          <div class=\"present-right\">${o?n(o):F``}</div>\n        </div>\n      `)}var s;return a.length>0?F`\n    <div class=\"present-grid-container\">\n      ${a}\n    </div>\n  `:F``},dt=(e,t,i,n,a)=>{const s=t||e.selectedLanguage||e.language,o=((e,t,i,n,a)=>{const s=Ue(t),o=a?e.states[a]:void 0,{next_rising:r,next_setting:l}=o?.attributes??{};return{nextRising:{value:r?new Date(r).toLocaleTimeString(s.locale,{hour:\"2-digit\",minute:\"2-digit\",second:\"2-digit\",hour12:!1,timeZone:s.timezone}):void 0,icon:\"mdi:weather-sunset-up\"},nextSetting:{value:r?new Date(l).toLocaleTimeString(s.locale,{hour:\"2-digit\",minute:\"2-digit\",second:\"2-digit\",hour12:!1,timeZone:s.timezone}):void 0,icon:\"mdi:weather-sunset-down\"},precipitationIntensity:{value:je({entityId:n.precipitation_intensity,hass:e,lang:t,decimals:2}),unit:Re(e,n.precipitation_intensity),icon:\"mdi:weather-rainy\"},precipitationProbability:{value:je({entityId:n.precipitation_probability,hass:e,lang:t,decimals:0}),unit:Re(e,n.precipitation_probability),icon:\"mdi:weather-rainy\"},humidity:{value:je({entityId:n.humidity,hass:e,lang:t,decimals:0}),unit:Re(e,n.humidity),icon:\"mdi:water-percent\"},windBearing:{value:Fe(Me(e,n.wind_bearing),i)},windSpeed:{value:je({entityId:n.wind_speed,hass:e,lang:t,decimals:0}),unit:Re(e,n.wind_speed),icon:\"mdi:weather-windy\"},pressure:{value:je({entityId:n.pressure,hass:e,lang:t,decimals:0}),unit:Re(e,n.pressure),icon:\"mdi:gauge\"},visibility:{value:je({entityId:n.visibility,hass:e,lang:t,decimals:0}),unit:Re(e,n.visibility),icon:\"mdi:weather-fog\"},temperatureHigh:{value:je({entityId:n.temperature_max,hass:e,lang:t,decimals:0}),unit:Re(e,n.temperature_max),icon:\"mdi:thermometer\"},temperatureLow:{value:je({entityId:n.temperature_min,hass:e,lang:t,decimals:0}),unit:Re(e,n.temperature_min),icon:\"mdi:thermometer\"}}})(e,s,i.windDirections,n,a);return ct({...o},s)},ht=[\"I\",\"II\",\"III\",\"IV\",\"V\",\"VI\"],ut=[\"#F1D1B1\",\"#E4B590\",\"#CF9F7D\",\"#B67851\",\"#A15E2D\",\"#513938\"],pt=(e,t)=>{const i=[],n=e=>F`\n    <span class=\"ultraviolet-value-block\">\n      ${e.value}${e.unit?F`<span class=\"ultraviolet-unit\">${e.unit}</span>`:\"\"}\n      <ha-icon icon=\"${e.icon}\" style=\"${\"on\"===e.value?\"color: red;\":\"\"}\"></ha-icon>\n    </span>\n  `,a=(e,t)=>{void 0!==t?.value&&i.push(t)};let s=[\"protectionWindow\",\"currentUVLevel\"];s.forEach((t=>a(0,e[t]))),void 0!==e.currentUVIndex?.value&&void 0!==e.maxUVIndex?.value&&i.push({icon:e.currentUVIndex.icon||e.maxUVIndex.icon||\"mdi:weather-sunny\",value:`${e.currentUVIndex.value} / ${e.maxUVIndex.value}`,unit:e.currentUVIndex.unit||e.maxUVIndex.unit}),s=[\"currentOzoneLevel\"],s.forEach((t=>a(0,e[t])));const o=[];for(let e=0;e<i.length;e+=2){const t=i[e],a=i[e+1];o.push(F`\n      <div class=\"ultraviolet-row\">\n        <div class=\"ultraviolet-left\">${t?(r=t,F`\n    <span class=\"ultraviolet-value-block\">\n      <ha-icon icon=\"${r.icon}\" style=\"${\"on\"===r.value?\"color: red;\":\"\"}\"></ha-icon>\n      ${r.value}${r.unit?F`<span class=\"ultraviolet-unit\">${r.unit}</span>`:\"\"}\n    </span>\n  `):F``}</div>\n        <div class=\"ultraviolet-right\">${a?n(a):F``}</div>\n      </div>\n    `)}var r;const l=[t.skinType1,t.skinType2,t.skinType3,t.skinType4,t.skinType5,t.skinType6],c=F`\n  <div class=\"ultraviolet-skin-type-grid\">\n  ${l.map(((e,t)=>{const i=ut[t],n=(e=>{const t=e.replace(\"#\",\"\");return(299*parseInt(t.substr(0,2),16)+587*parseInt(t.substr(2,2),16)+114*parseInt(t.substr(4,2),16))/1e3>125?\"#000\":\"#fff\"})(i);return F`\n      <div\n        class=\"ultraviolet-skin-type-cell\"\n        style=\"background: ${i};\"\n        title=\"Fototipo ${ht[t]}\"\n      >\n        <div class=\"ultraviolet-skin-type-label\">${ht[t]}</div>\n        <div class=\"ultraviolet-exposure-time\" style=\"color: ${n};\">${e.value||\"--\"}</div>\n      </div>\n    `}))}\n  </div>\n  `;return F`\n    <div class=\"ultraviolet-grid-container\">\n      ${o}\n      ${c}\n    </div>\n  `},mt=e=>{const t=\"string\"==typeof e&&\"unknown\"===e.toLowerCase()?NaN:Number(e);if(!Number.isFinite(t)||t<0)return\"--\";const i=Math.floor(t/60),n=t%60;return i>0?`${i}:${function(e,t,i=\"0\"){return e.toString().padStart(t,i)}(n,2)} h`:`${n} m`},gt=(e,t,i)=>({protectionWindow:{value:Me(e,i.protection_window)&&\"unknown\"!==Me(e,i.protection_window)?Me(e,i.protection_window):\"off\",icon:\"mdi:sunglasses\"},currentUVLevel:{value:Me(e,i.uv_level),icon:\"mdi:weather-sunny\"},currentUVIndex:{value:je({entityId:i.uv_index,hass:e,lang:t}),unit:\"UV Idx\",icon:\"mdi:weather-sunny\"},maxUVIndex:{value:je({entityId:i.max_uv_index,hass:e,lang:t}),unit:\"UV Idx\",icon:\"mdi:weather-sunny\"},currentOzoneLevel:{value:je({entityId:i.ozone_level,hass:e,lang:t}),unit:\"DU\",icon:\"mdi:vector-triangle\"}}),yt=(e,t,i)=>({skinType1:{value:mt(je({entityId:i.set_skin_type_1,hass:e,lang:t}))},skinType2:{value:mt(je({entityId:i.set_skin_type_2,hass:e,lang:t}))},skinType3:{value:mt(je({entityId:i.set_skin_type_3,hass:e,lang:t}))},skinType4:{value:mt(je({entityId:i.set_skin_type_4,hass:e,lang:t}))},skinType5:{value:mt(je({entityId:i.set_skin_type_5,hass:e,lang:t}))},skinType6:{value:mt(je({entityId:i.set_skin_type_6,hass:e,lang:t}))}}),ft=[\"basso\",\"moderato\",\"alto\",\"molto-alto\",\"estremo\"],vt=(e,t,i)=>{const n=i-t+1,a=ft.slice(0,n);return 0===e.length?F``:F`\n    <div class=\"pollen-grid-container\">\n      ${e.map((e=>{const n=((e,t,i)=>{const n=(i-t+1)/ft.length,a=Math.floor((e-t)/n);return Math.min(a,ft.length-1)})(e.value,t,i);return F`\n          <div class=\"pollen-stack\">\n            <div class=\"levels\">\n              ${a.map(((e,t)=>F`\n                <div\n                  class=\"level ${e} ${t===n?\"active\":\"\"}\"\n                  title=\"${e}\"\n                ></div>\n              `))}\n            </div>\n            <div class=\"pollen-name\">${e.name}</div>\n          </div>\n        `}))}\n    </div>\n  `},_t=(e,t,i)=>{const n=[];return Array.isArray(i.entities)&&i.entities.length>0&&i.entities.forEach((t=>{const a=Me(e,t.entity);if(a&&\"unknown\"!==a&&\"unavailable\"!==a){let a=((e,t=\"en-US\")=>{if(\"number\"==typeof e)return e;const i=new Intl.NumberFormat(t).formatToParts(1234567.89),n=i.find((e=>\"group\"===e.type))?.value||\"\",a=i.find((e=>\"decimal\"===e.type))?.value||\".\",s=e.replace(new RegExp(`\\\\${n}`,\"g\"),\"\").replace(new RegExp(`\\\\${a}`),\".\");return Number(s)})(Me(e,t.entity));(Number.isNaN(a)||a<i.min||a>i.max)&&(a=0),n.push({name:t.name,value:a})}})),vt(n,i.min,i.max)},wt=(e,t)=>{const i=t.map((e=>{const t=e.reference?.value,i=e.condition?.img,n=e.condition?.icon,a=e.condition?.iconColor,s=e.temperature_low?.value,o=e.temperature_high?.value,r=e.temperature_high?.unit||e.temperature_low?.unit,l=Number(e.precipitation_probability?.value??0),c=e.precipitation_intensity?.value,d=e.precipitation_intensity?.unit,h=e.temperature?.value,u=e.temperature?.unit||e.temperature_feelslike?.unit,p=e.temperature_feelslike?.value,m=e.wind_speed?.value,g=e.wind_speed?.unit,y=e.wind_bearing?.value,f=e.wind_wave_height_max?.value,v=e.swell_wave_height_max?.value,_=e.wave_height_max?.value,w=e.wave_direction?.value,$=e.wave_direction?.icon,x=e.wave_height_max?.unit;return F`\n      <div class=\"weather-forecast-slot\">\n        ${t?F`<div class=\"weather-forecast-label-slot\">${t}</div>`:\"\"}\n        ${i?F`<img class=\"weather-forecast-icon\" src=\"${i}\" alt=\"${i}\" />`:\"\"}\n        ${n?F`<ha-icon icon=\"${n}\" style=${a?`color: ${a}`:\"\"}></ha-icon>`:\"\"}\n        ${void 0!==s&&void 0!==o?F`\n                <div class=\"weather-forecast-temperature\">\n                  ${s} / <span class=\"high\">${o}${r?` ${r}`:\"\"}</span>\n                </div>\n              `:\"\"}\n        ${void 0!==h&&void 0!==p?F`\n                <div class=\"weather-forecast-temperature\">\n                  ${h} / <span class=\"high\">${p}${u?` ${u}`:\"\"}</span>\n                </div>\n              `:\"\"}\n        ${void 0!==m&&void 0!==y?F`\n                <div class=\"weather-forecast-temperature\">\n                  ${m} ${g} ${y}</span>\n                </div>\n              `:\"\"}\n        ${void 0!==_?F`\n                <div class=\"weather-forecast-temperature\">\n                  ${_} ${x?` ${x}`:\"\"}\n                </div>\n              `:\"\"}\n        ${void 0!==w?F`\n                <div class=\"weather-forecast-temperature\">\n                  ${$?F`<ha-icon\n                        icon=\"mdi:arrow-up-thin\"\n                        style=\"display:inline-block; transform: rotate(${$}deg);\"\n                      ></ha-icon>`:\"\"} ${w}\n                </div>\n              `:\"\"}\n        ${void 0!==f&&void 0!==v?F`\n                <div class=\"weather-forecast-temperature\">\n                  ${v} / ${f} ${x?` ${x}`:\"\"}\n                </div>\n              `:\"\"}\n        ${void 0!==l&&void 0!==c&&0!==l?F`\n                <div class=\"weather-forecast-precipitation\">\n                  ${l} % / <span class=\"mm\">${c}${d?` ${d}`:\"\"}</span>\n                </div>\n              `:\"\"}\n      </div>\n    `}));let n=\"Daily\";return 1===e?n=\"Hourly\":2===e?n=\"Marine daily\":3===e&&(n=\"Marine hourly\"),F`\n  <div class=\"weather-forecast-grid-wrapper\">\n    <div class=\"weather-forecast-title\">${n} forecast</div>\n    <div class=\"weather-forecast-grid-container\">\n      ${i}\n    </div>\n  </div>\n  `},$t=e=>e.includes(\"temperature\")?\"mdi:thermometer\":e.includes(\"precipitation\")?\"mdi:weather-rainy\":\"mdi:help-circle-outline\",xt=(e,t,i,n,a,s,o,r,l,c)=>{const d=[],h=Me(e,c);let u=d;if(n){u=Object.keys(n.condition||n.temperature_high||n.temperature_low||n.precipitation_intensity||n.precipitation_probability||{}).map((i=>((e,t,i,n,a,s,o)=>{const r={},l=Ue(t);let c;if(i.condition&&i.condition[o]&&(r.condition={img:tt(Me(e,i.condition[o]),a,s)}),[\"temperature_high\",\"temperature_low\",\"precipitation_intensity\",\"precipitation_probability\"].forEach((n=>{const a=i[n],s=a?.[o];let l=0;s&&(\"precipitation_intensity\"===n&&(l=2),c=new Date(Le(e,s,\"datetime\")),r[n]={value:je({entityId:s,hass:e,lang:t,decimals:l}),unit:Re(e,s),img:He(e,s)||$t(n)})})),c&&Object.keys(r).length>0){const e=c.toLocaleDateString(l.locale,{weekday:\"short\",timeZone:\"UTC\"}),t=c.toLocaleTimeString(l.locale,{hour:\"2-digit\",minute:\"2-digit\",timeZone:l.timezone});r.reference={value:0===n?e.toUpperCase():t}}return r})(e,t,n,r,l,h,i)))}let p=d;if(a){p=Object.keys(a.condition||a.temperature||a.temperature_feelslike||a.precipitation_intensity||a.precipitation_probability||{}).map((n=>((e,t,i,n,a,s,o,r)=>{const l={},c=Ue(t);let d;if(n.condition&&n.condition[r]&&(l.condition={img:tt(Me(e,n.condition[r]),s,o)}),n.wind_bearing&&n.wind_bearing[r]&&(l.wind_bearing={value:Fe(Me(e,n.wind_bearing[r]),i)}),[\"temperature\",\"temperature_feelslike\",\"precipitation_intensity\",\"precipitation_probability\",\"wind_speed\"].forEach((i=>{const a=n[i],s=a?.[r];let o=0;s&&(\"precipitation_intensity\"===i&&(o=2),d=new Date(Le(e,s,\"datetime\")),l[i]={value:je({entityId:s,hass:e,lang:t,decimals:o}),unit:Re(e,s),img:He(e,s)||$t(i)})})),d&&Object.keys(l).length>0){const e=d.toLocaleTimeString(c.locale,{hour:\"2-digit\",minute:\"2-digit\",timeZone:c.timezone});l.reference={value:e}}return l})(e,t,i.windDirections,a,0,l,h,n)))}let m=d;if(s){m=Object.keys(s.swell_wave_height_max||s.wave_direction||s.wave_height_max||s.wind_wave_height_max||{}).map((n=>((e,t,i,n,a,s,o,r)=>{const l={},c=Ue(t);let d;var h,u,p;if(n.wave_height_max&&n.swell_wave_height_max&&n.wind_wave_height_max&&n.swell_wave_height_max[r]&&n.wind_wave_height_max[r]&&(l.condition={icon:\"mdi:flag-variant\",iconColor:(h=n.wave_height_max[r],u=n.swell_wave_height_max[r],p=n.wind_wave_height_max[r],h>=1.8||u>=1.5&&p>=.8?\"red\":h>=1||u>=.8||p>=.6?\"yellow\":\"green\")}),n.wave_direction&&n.wave_direction[r]&&(l.wave_direction={value:Fe(Me(e,n.wave_direction[r]),i),icon:Me(e,n.wave_direction[r])}),[\"wave_height_max\",\"swell_wave_height_max\",\"wind_wave_height_max\"].forEach((i=>{const a=n[i],s=a?.[r];s&&(d=new Date(Le(e,s,\"datetime\")),l[i]={value:je({entityId:s,hass:e,lang:t,decimals:1}),unit:Re(e,s),img:He(e,s)||$t(i)})})),d&&Object.keys(l).length>0){const e=d.toLocaleDateString(c.locale,{weekday:\"short\",timeZone:\"UTC\"}),t=d.toLocaleTimeString(c.locale,{hour:\"2-digit\",minute:\"2-digit\",timeZone:c.timezone});l.reference={value:2===a?e.toUpperCase():t}}return l})(e,t,i.windDirections,s,r,0,0,n)))}switch(r){case 0:return wt(r,u);case 1:return wt(r,p);case 2:return wt(r,m);default:return wt(r,d)}},bt=(e,t,i,n,a)=>{const s=a&&e.states[a],o=s?.attributes?.entity_picture;return((e,t,i,n)=>i?F`\n    <div \n      class=\"camera-container\"\n      @click=${i=>e(i,t)}\n    >\n      <div class=\"camera-image\">\n        <img \n          src=\"${i}\" \n          alt=\"${n}\"\n          loading=\"lazy\"\n        />\n      </div>\n    </div>\n  `:F``)(n,a,o,s?.attributes?.friendly_name??a)};const At=(e,t,i,n)=>{const a={wind:\"mdi:weather-windy\",\"snow-ice\":\"mdi:snowflake-alert\",thunderstorm:\"mdi:weather-lightning\",fog:\"mdi:weather-fog\",\"high-temperature\":\"mdi:weather-sunny-alert\",\"low-temperature\":\"mdi:thermometer-low\",\"coastal-event\":\"mdi:home-flood\",\"forest-fire\":\"mdi:pine-tree-fire\",avalanche:\"mdi:image-filter-hdr\",rain:\"mdi:weather-pouring\",flood:\"mdi:home-flood\",\"rain-flood\":\"mdi:weather-pouring\",\"marine-hazard\":\"mdi:weather-hurricane\",drought:\"mdi:water-off\"},s={green:\"green\",yellow:\"#ffa600\",orange:\"orange\",red:\"red\"},o=n&&e.states[n];if(!o?.attributes)return{};const r={};if(\"on\"===o.state&&o.attributes){const e=Ue(t),{event:i,severity:n,awareness_type:l,awareness_level:c,effective:d}=o.attributes,h=l?.split(\";\")[1]?.trim().toLowerCase()||\"\",u=c?.split(\";\")[1]?.trim().toLowerCase()||\"\",p=i||\"\",m=n?.split(\";\")[1]?.trim()||\"\";(e=>{const t=new Date(e),i=new Date,n=new Date(i.getFullYear(),i.getMonth(),i.getDate()),a=new Date(t.getFullYear(),t.getMonth(),t.getDate()),s=Math.round((a.getTime()-n.getTime())/864e5);let o;o=0===s?\"oggi\":1===s?\"domani\":2===s?\"dopodomani\":void 0})(d),r.meteoalarm={event:p,severity:m,icon:a[h]||\"mdi:alert\",icon_color:s[u]||\"grey\",datetime:new Date(d).toLocaleDateString(e.locale,{weekday:\"short\",timeZone:e.timezone}).toLocaleUpperCase()}}return r},zt=(e,t,i,n)=>{if(!n)return{};const a=Ue(t),s={0:\"gray\",1:\"green\",2:\"#ffa600\",3:\"orange\",4:\"red\"},o={};return[\"thunderstorms\",\"hydraulic\",\"hydrogeological\"].forEach((t=>{const i=n[t],r=i&&e.states[i];if(r&&\"on\"===r.state&&r.attributes){const{level:e,info:i,icon:n}=r.attributes;o[t]={event:i,severity:e,icon:n,icon_color:s[e],datetime:(new Date).toLocaleDateString(a.locale,{weekday:\"short\",timeZone:a.timezone}).toLocaleUpperCase()}}})),o},Et=(e,t,i,n,a)=>{const s={...At(e,t,0,n),...zt(e,t,0,a)};return(o=s)&&0!==Object.keys(o).length?F`\n  <div class=\"meteodcpalarm-grid-container\">\n    ${Object.entries(o).map((([e,t])=>F`\n      <div class=\"meteodcpalarm-group\">\n        <ha-icon icon=\"${t.icon}\" style=\"color: ${t.icon_color};\"></ha-icon>\n        <div class=\"meteodcpalarm-label\">${t.datetime}</div>\n        <div class=\"meteodcpalarm-label\">${t.event}</div>\n      </div>\n    `))}\n  </div>\n  `:F``;var o},{translations:kt,imagePath:St}=await nt();let Ct=class extends at{constructor(){super(...arguments),this._translations=kt,this._imagesPath=St}_render(){return F`\n      <ha-card class=\"ha-card-weather-conditions\">\n        <div class=\"nd-container\">\n          ${this._buildTemplate()}\n        </div>\n      </ha-card>\n    `}_buildTemplate(){let e=F``,t=F``,i=F``,n=F``,a=F``,s=F``,o=F``,r=F``,l=F``,c=F``,d=F``;const h=e=>xt(this.hass,this._language,this._terms,this._config.weather.daily_forecasts,this._config.weather.hourly_forecasts,this._config.weather.marine_daily_forecasts,this._config.weather.marine_hourly_forecasts,e,this._iconsConfig,this._config.weather.sun);var u,p,m;return this._hasPresent&&(e=st(this.hass,this._language,this._terms,this._iconsConfig,this._config.weather?.name,this._config?.weather?.present||null,this._config?.weather?.sun,this._config?.weather?.moonphase)),this._hasPresent&&(t=dt(this.hass,this._language,this._terms,this._config?.weather?.present||{},this._config?.weather?.sun)),(this._hasMetealarm||this._hasDPCalarm)&&(o=Et(this.hass,this._language,this._terms,this._config?.weather?.meteoalarm,this._config?.weather?.dpcalarm)),this._hasDailyForecasts&&(i=h(0)),this._hasHourlyForecasts&&(n=h(1)),this._hasMarineDailyForecasts&&(a=h(2)),this._hasMarineHourlyForecasts&&(s=h(3)),this._hasUltraviolet&&(u=this.hass,p=this._language,m=this._config.ultraviolet,r=pt({...gt(u,p,m)},{...yt(u,p,m)})),this._hasPollen&&(l=_t(this.hass,this._language,this._config.pollen)),this._hasAirQuality&&(c=((e,t,i)=>{const n=t||e.selectedLanguage||e.language,a=je({entityId:i.pm25,hass:e,lang:t,decimals:0}),s=je({entityId:i.pm10,hass:e,lang:t,decimals:0}),o=je({entityId:i.o3,hass:e,lang:t,decimals:1}),r=je({entityId:i.no2,hass:e,lang:t,decimals:0}),l=je({entityId:i.co,hass:e,lang:t,decimals:1}),c=je({entityId:i.so2,hass:e,lang:t,decimals:0}),d=je({entityId:i.epa_aqi,hass:e,lang:t,decimals:0}),h=Me(e,i.epa_primary_pollutant),u={pm25:{value:a?`pm2.5 ${a}`:a,unit:Re(e,i.pm25)||\"µg/m³\",icon:\"mdi:weather-hazy\"},pm10:{value:s?`pm10 ${s}`:s,unit:Re(e,i.pm10)||\"µg/m³\",icon:\"mdi:weather-hazy\"},o3:{value:o?`o3 ${o}`:o,unit:Re(e,i.o3)||\"µg/m³\",icon:\"mdi:molecule\"},no2:{value:r?`no2 ${r}`:r,unit:Re(e,i.no2)||\"µg/m³\",icon:\"mdi:molecule\"},co:{value:l?`co ${l}`:l,unit:Re(e,i.co)||\"µg/m³\",icon:\"mdi:molecule\"},so2:{value:c?`so2 ${c}`:c,unit:Re(e,i.so2)||\"µg/m³\",icon:\"mdi:molecule\"},epa_aqi:{value:d?`Air Quality Index ${d}`:d,icon:\"mdi:weather-hazy\",icon_color:(p=Number(Me(e,i.epa_aqi)),p<=50?\"#009966\":p<=100?\"#ffde33\":p<=150?\"#ff9933\":p<=200?\"#cc0033\":p<=300?\"#660099\":\"#7e0023\")},epa_primary_pollutant:{value:h?`Primary ${h}`:h,icon:\"mdi:weather-hazy\"}};var p;return ct(u,n)})(this.hass,this._language,this._config.airquality)),this._hasCamera&&(d=bt(this.hass,this._language,this._terms,this._handlePopup.bind(this),this._config.camera)),F`\n    ${e}\n    ${t}\n    ${n}\n    ${i}\n    ${s}\n    ${a}\n    ${o}\n    ${l}\n    ${r}\n    ${c}\n    ${d}`}_handlePopup(e,t){e.stopPropagation();const i=new Event(\"hass-more-info\",{composed:!0});i.detail={entityId:t},this.dispatchEvent(i)}};Ct=e([(e=>(t,i)=>{void 0!==i?i.addInitializer((()=>{customElements.define(e,t)})):customElements.define(e,t)})(\"ha-card-weather-conditions\")],Ct);export{Ct as HaCardWeatherConditions};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ha-card-weather-conditions.js","sources":["../node_modules/tslib/tslib.es6.js","../node_modules/@lit/reactive-element/css-tag.js","../node_modules/@lit/reactive-element/reactive-element.js","../node_modules/lit-html/lit-html.js","../node_modules/lit-element/lit-element.js","../node_modules/@lit/reactive-element/decorators/custom-element.js","../node_modules/@lit/reactive-element/decorators/property.js","../src/utils/colors.ts","../src/utils/const.ts","../src/iconmodels/im-buienradar.ts","../src/iconmodels/im-climacell.ts","../src/iconmodels/im-darksky.ts","../src/iconmodels/im-hass.ts","../src/iconmodels/im-openweathermap.ts","../src/iconmodels/im-pirateweather.ts","../backup/types.ts","../src/utils/helper.ts","../backup/ha-cwc-consts.ts","../src/css/css-base-card.ts","../src/css/css-summary.ts","../src/css/css-present.ts","../src/css/css-ultraviolet.ts","../src/css/css-pollen.ts","../src/css/css-camera.ts","../src/css/css-weather-forecast.ts","../src/css/css-meteoalarm.ts","../src/utils/helper-render.ts","../src/base/lovelace-base.ts","../src/templates/t-summary.ts","../src/builder/b-summary.ts","../src/templates/t-present.ts","../src/builder/b-present.ts","../src/templates/t-ultraviolet.ts","../src/builder/b-ultraviolet.ts","../src/templates/t-pollen.ts","../src/builder/b-pollen.ts","../src/templates/t-weather-forecast.ts","../src/builder/b-weather-forecast.ts","../src/builder/b-camera.ts","../src/templates/t-camera.ts","../src/builder/b-airquality.ts","../src/builder/b-meteoalarm.ts","../src/templates/t-meteoalarm.ts","../src/ha-weather-ecard.ts"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    if (typeof b !== \"function\" && b !== null)\r\n        throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n    function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n    var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n    var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n    var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n    var _, done = false;\r\n    for (var i = decorators.length - 1; i >= 0; i--) {\r\n        var context = {};\r\n        for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n        for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n        context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n        var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n        if (kind === \"accessor\") {\r\n            if (result === void 0) continue;\r\n            if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n            if (_ = accept(result.get)) descriptor.get = _;\r\n            if (_ = accept(result.set)) descriptor.set = _;\r\n            if (_ = accept(result.init)) initializers.unshift(_);\r\n        }\r\n        else if (_ = accept(result)) {\r\n            if (kind === \"field\") initializers.unshift(_);\r\n            else descriptor[key] = _;\r\n        }\r\n    }\r\n    if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n    done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n    var useValue = arguments.length > 2;\r\n    for (var i = 0; i < initializers.length; i++) {\r\n        value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n    }\r\n    return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n    return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n    if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n    return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n    return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    var desc = Object.getOwnPropertyDescriptor(m, k);\r\n    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n        desc = { enumerable: true, get: function() { return m[k]; } };\r\n    }\r\n    Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n    for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n        if (ar || !(i in from)) {\r\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n            ar[i] = from[i];\r\n        }\r\n    }\r\n    return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n    function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n    o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n    ownKeys = Object.getOwnPropertyNames || function (o) {\r\n        var ar = [];\r\n        for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n        return ar;\r\n    };\r\n    return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n    __setModuleDefault(result, mod);\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n    return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n    if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n    return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n    if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n    return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n    if (value !== null && value !== void 0) {\r\n        if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n        var dispose, inner;\r\n        if (async) {\r\n            if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n            dispose = value[Symbol.asyncDispose];\r\n        }\r\n        if (dispose === void 0) {\r\n            if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n            dispose = value[Symbol.dispose];\r\n            if (async) inner = dispose;\r\n        }\r\n        if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n        if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n        env.stack.push({ value: value, dispose: dispose, async: async });\r\n    }\r\n    else if (async) {\r\n        env.stack.push({ async: true });\r\n    }\r\n    return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n    var e = new Error(message);\r\n    return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n    function fail(e) {\r\n        env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n        env.hasError = true;\r\n    }\r\n    var r, s = 0;\r\n    function next() {\r\n        while (r = env.stack.pop()) {\r\n            try {\r\n                if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n                if (r.dispose) {\r\n                    var result = r.dispose.call(r.value);\r\n                    if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n                }\r\n                else s |= 1;\r\n            }\r\n            catch (e) {\r\n                fail(e);\r\n            }\r\n        }\r\n        if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n        if (env.hasError) throw env.error;\r\n    }\r\n    return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n    if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n        return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n            return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n        });\r\n    }\r\n    return path;\r\n}\r\n\r\nexport default {\r\n    __extends: __extends,\r\n    __assign: __assign,\r\n    __rest: __rest,\r\n    __decorate: __decorate,\r\n    __param: __param,\r\n    __esDecorate: __esDecorate,\r\n    __runInitializers: __runInitializers,\r\n    __propKey: __propKey,\r\n    __setFunctionName: __setFunctionName,\r\n    __metadata: __metadata,\r\n    __awaiter: __awaiter,\r\n    __generator: __generator,\r\n    __createBinding: __createBinding,\r\n    __exportStar: __exportStar,\r\n    __values: __values,\r\n    __read: __read,\r\n    __spread: __spread,\r\n    __spreadArrays: __spreadArrays,\r\n    __spreadArray: __spreadArray,\r\n    __await: __await,\r\n    __asyncGenerator: __asyncGenerator,\r\n    __asyncDelegator: __asyncDelegator,\r\n    __asyncValues: __asyncValues,\r\n    __makeTemplateObject: __makeTemplateObject,\r\n    __importStar: __importStar,\r\n    __importDefault: __importDefault,\r\n    __classPrivateFieldGet: __classPrivateFieldGet,\r\n    __classPrivateFieldSet: __classPrivateFieldSet,\r\n    __classPrivateFieldIn: __classPrivateFieldIn,\r\n    __addDisposableResource: __addDisposableResource,\r\n    __disposeResources: __disposeResources,\r\n    __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t=globalThis,e=t.ShadowRoot&&(void 0===t.ShadyCSS||t.ShadyCSS.nativeShadow)&&\"adoptedStyleSheets\"in Document.prototype&&\"replace\"in CSSStyleSheet.prototype,s=Symbol(),o=new WeakMap;class n{constructor(t,e,o){if(this._$cssResult$=!0,o!==s)throw Error(\"CSSResult is not constructable. Use `unsafeCSS` or `css` instead.\");this.cssText=t,this.t=e}get styleSheet(){let t=this.o;const s=this.t;if(e&&void 0===t){const e=void 0!==s&&1===s.length;e&&(t=o.get(s)),void 0===t&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),e&&o.set(s,t))}return t}toString(){return this.cssText}}const r=t=>new n(\"string\"==typeof t?t:t+\"\",void 0,s),i=(t,...e)=>{const o=1===t.length?t[0]:e.reduce(((e,s,o)=>e+(t=>{if(!0===t._$cssResult$)return t.cssText;if(\"number\"==typeof t)return t;throw Error(\"Value passed to 'css' function must be a 'css' function result: \"+t+\". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.\")})(s)+t[o+1]),t[0]);return new n(o,t,s)},S=(s,o)=>{if(e)s.adoptedStyleSheets=o.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet));else for(const e of o){const o=document.createElement(\"style\"),n=t.litNonce;void 0!==n&&o.setAttribute(\"nonce\",n),o.textContent=e.cssText,s.appendChild(o)}},c=e?t=>t:t=>t instanceof CSSStyleSheet?(t=>{let e=\"\";for(const s of t.cssRules)e+=s.cssText;return r(e)})(t):t;export{n as CSSResult,S as adoptStyles,i as css,c as getCompatibleStyle,e as supportsAdoptingStyleSheets,r as unsafeCSS};\n//# sourceMappingURL=css-tag.js.map\n","import{getCompatibleStyle as t,adoptStyles as s}from\"./css-tag.js\";export{CSSResult,css,supportsAdoptingStyleSheets,unsafeCSS}from\"./css-tag.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const{is:i,defineProperty:e,getOwnPropertyDescriptor:h,getOwnPropertyNames:r,getOwnPropertySymbols:o,getPrototypeOf:n}=Object,a=globalThis,c=a.trustedTypes,l=c?c.emptyScript:\"\",p=a.reactiveElementPolyfillSupport,d=(t,s)=>t,u={toAttribute(t,s){switch(s){case Boolean:t=t?l:null;break;case Object:case Array:t=null==t?t:JSON.stringify(t)}return t},fromAttribute(t,s){let i=t;switch(s){case Boolean:i=null!==t;break;case Number:i=null===t?null:Number(t);break;case Object:case Array:try{i=JSON.parse(t)}catch(t){i=null}}return i}},f=(t,s)=>!i(t,s),b={attribute:!0,type:String,converter:u,reflect:!1,useDefault:!1,hasChanged:f};Symbol.metadata??=Symbol(\"metadata\"),a.litPropertyMetadata??=new WeakMap;class y extends HTMLElement{static addInitializer(t){this._$Ei(),(this.l??=[]).push(t)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(t,s=b){if(s.state&&(s.attribute=!1),this._$Ei(),this.prototype.hasOwnProperty(t)&&((s=Object.create(s)).wrapped=!0),this.elementProperties.set(t,s),!s.noAccessor){const i=Symbol(),h=this.getPropertyDescriptor(t,i,s);void 0!==h&&e(this.prototype,t,h)}}static getPropertyDescriptor(t,s,i){const{get:e,set:r}=h(this.prototype,t)??{get(){return this[s]},set(t){this[s]=t}};return{get:e,set(s){const h=e?.call(this);r?.call(this,s),this.requestUpdate(t,h,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)??b}static _$Ei(){if(this.hasOwnProperty(d(\"elementProperties\")))return;const t=n(this);t.finalize(),void 0!==t.l&&(this.l=[...t.l]),this.elementProperties=new Map(t.elementProperties)}static finalize(){if(this.hasOwnProperty(d(\"finalized\")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(d(\"properties\"))){const t=this.properties,s=[...r(t),...o(t)];for(const i of s)this.createProperty(i,t[i])}const t=this[Symbol.metadata];if(null!==t){const s=litPropertyMetadata.get(t);if(void 0!==s)for(const[t,i]of s)this.elementProperties.set(t,i)}this._$Eh=new Map;for(const[t,s]of this.elementProperties){const i=this._$Eu(t,s);void 0!==i&&this._$Eh.set(i,t)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(s){const i=[];if(Array.isArray(s)){const e=new Set(s.flat(1/0).reverse());for(const s of e)i.unshift(t(s))}else void 0!==s&&i.push(t(s));return i}static _$Eu(t,s){const i=s.attribute;return!1===i?void 0:\"string\"==typeof i?i:\"string\"==typeof t?t.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise((t=>this.enableUpdating=t)),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach((t=>t(this)))}addController(t){(this._$EO??=new Set).add(t),void 0!==this.renderRoot&&this.isConnected&&t.hostConnected?.()}removeController(t){this._$EO?.delete(t)}_$E_(){const t=new Map,s=this.constructor.elementProperties;for(const i of s.keys())this.hasOwnProperty(i)&&(t.set(i,this[i]),delete this[i]);t.size>0&&(this._$Ep=t)}createRenderRoot(){const t=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return s(t,this.constructor.elementStyles),t}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach((t=>t.hostConnected?.()))}enableUpdating(t){}disconnectedCallback(){this._$EO?.forEach((t=>t.hostDisconnected?.()))}attributeChangedCallback(t,s,i){this._$AK(t,i)}_$ET(t,s){const i=this.constructor.elementProperties.get(t),e=this.constructor._$Eu(t,i);if(void 0!==e&&!0===i.reflect){const h=(void 0!==i.converter?.toAttribute?i.converter:u).toAttribute(s,i.type);this._$Em=t,null==h?this.removeAttribute(e):this.setAttribute(e,h),this._$Em=null}}_$AK(t,s){const i=this.constructor,e=i._$Eh.get(t);if(void 0!==e&&this._$Em!==e){const t=i.getPropertyOptions(e),h=\"function\"==typeof t.converter?{fromAttribute:t.converter}:void 0!==t.converter?.fromAttribute?t.converter:u;this._$Em=e,this[e]=h.fromAttribute(s,t.type)??this._$Ej?.get(e)??null,this._$Em=null}}requestUpdate(t,s,i){if(void 0!==t){const e=this.constructor,h=this[t];if(i??=e.getPropertyOptions(t),!((i.hasChanged??f)(h,s)||i.useDefault&&i.reflect&&h===this._$Ej?.get(t)&&!this.hasAttribute(e._$Eu(t,i))))return;this.C(t,s,i)}!1===this.isUpdatePending&&(this._$ES=this._$EP())}C(t,s,{useDefault:i,reflect:e,wrapped:h},r){i&&!(this._$Ej??=new Map).has(t)&&(this._$Ej.set(t,r??s??this[t]),!0!==h||void 0!==r)||(this._$AL.has(t)||(this.hasUpdated||i||(s=void 0),this._$AL.set(t,s)),!0===e&&this._$Em!==t&&(this._$Eq??=new Set).add(t))}async _$EP(){this.isUpdatePending=!0;try{await this._$ES}catch(t){Promise.reject(t)}const t=this.scheduleUpdate();return null!=t&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(const[t,s]of this._$Ep)this[t]=s;this._$Ep=void 0}const t=this.constructor.elementProperties;if(t.size>0)for(const[s,i]of t){const{wrapped:t}=i,e=this[s];!0!==t||this._$AL.has(s)||void 0===e||this.C(s,void 0,i,e)}}let t=!1;const s=this._$AL;try{t=this.shouldUpdate(s),t?(this.willUpdate(s),this._$EO?.forEach((t=>t.hostUpdate?.())),this.update(s)):this._$EM()}catch(s){throw t=!1,this._$EM(),s}t&&this._$AE(s)}willUpdate(t){}_$AE(t){this._$EO?.forEach((t=>t.hostUpdated?.())),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t)}_$EM(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(t){return!0}update(t){this._$Eq&&=this._$Eq.forEach((t=>this._$ET(t,this[t]))),this._$EM()}updated(t){}firstUpdated(t){}}y.elementStyles=[],y.shadowRootOptions={mode:\"open\"},y[d(\"elementProperties\")]=new Map,y[d(\"finalized\")]=new Map,p?.({ReactiveElement:y}),(a.reactiveElementVersions??=[]).push(\"2.1.0\");export{y as ReactiveElement,s as adoptStyles,u as defaultConverter,t as getCompatibleStyle,f as notEqual};\n//# sourceMappingURL=reactive-element.js.map\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t=globalThis,i=t.trustedTypes,s=i?i.createPolicy(\"lit-html\",{createHTML:t=>t}):void 0,e=\"$lit$\",h=`lit$${Math.random().toFixed(9).slice(2)}$`,o=\"?\"+h,n=`<${o}>`,r=document,l=()=>r.createComment(\"\"),c=t=>null===t||\"object\"!=typeof t&&\"function\"!=typeof t,a=Array.isArray,u=t=>a(t)||\"function\"==typeof t?.[Symbol.iterator],d=\"[ \\t\\n\\f\\r]\",f=/<(?:(!--|\\/[^a-zA-Z])|(\\/?[a-zA-Z][^>\\s]*)|(\\/?$))/g,v=/-->/g,_=/>/g,m=RegExp(`>|${d}(?:([^\\\\s\"'>=/]+)(${d}*=${d}*(?:[^ \\t\\n\\f\\r\"'\\`<>=]|(\"|')|))|$)`,\"g\"),p=/'/g,g=/\"/g,$=/^(?:script|style|textarea|title)$/i,y=t=>(i,...s)=>({_$litType$:t,strings:i,values:s}),x=y(1),b=y(2),w=y(3),T=Symbol.for(\"lit-noChange\"),E=Symbol.for(\"lit-nothing\"),A=new WeakMap,C=r.createTreeWalker(r,129);function P(t,i){if(!a(t)||!t.hasOwnProperty(\"raw\"))throw Error(\"invalid template strings array\");return void 0!==s?s.createHTML(i):i}const V=(t,i)=>{const s=t.length-1,o=[];let r,l=2===i?\"<svg>\":3===i?\"<math>\":\"\",c=f;for(let i=0;i<s;i++){const s=t[i];let a,u,d=-1,y=0;for(;y<s.length&&(c.lastIndex=y,u=c.exec(s),null!==u);)y=c.lastIndex,c===f?\"!--\"===u[1]?c=v:void 0!==u[1]?c=_:void 0!==u[2]?($.test(u[2])&&(r=RegExp(\"</\"+u[2],\"g\")),c=m):void 0!==u[3]&&(c=m):c===m?\">\"===u[0]?(c=r??f,d=-1):void 0===u[1]?d=-2:(d=c.lastIndex-u[2].length,a=u[1],c=void 0===u[3]?m:'\"'===u[3]?g:p):c===g||c===p?c=m:c===v||c===_?c=f:(c=m,r=void 0);const x=c===m&&t[i+1].startsWith(\"/>\")?\" \":\"\";l+=c===f?s+n:d>=0?(o.push(a),s.slice(0,d)+e+s.slice(d)+h+x):s+h+(-2===d?i:x)}return[P(t,l+(t[s]||\"<?>\")+(2===i?\"</svg>\":3===i?\"</math>\":\"\")),o]};class N{constructor({strings:t,_$litType$:s},n){let r;this.parts=[];let c=0,a=0;const u=t.length-1,d=this.parts,[f,v]=V(t,s);if(this.el=N.createElement(f,n),C.currentNode=this.el.content,2===s||3===s){const t=this.el.content.firstChild;t.replaceWith(...t.childNodes)}for(;null!==(r=C.nextNode())&&d.length<u;){if(1===r.nodeType){if(r.hasAttributes())for(const t of r.getAttributeNames())if(t.endsWith(e)){const i=v[a++],s=r.getAttribute(t).split(h),e=/([.?@])?(.*)/.exec(i);d.push({type:1,index:c,name:e[2],strings:s,ctor:\".\"===e[1]?H:\"?\"===e[1]?I:\"@\"===e[1]?L:k}),r.removeAttribute(t)}else t.startsWith(h)&&(d.push({type:6,index:c}),r.removeAttribute(t));if($.test(r.tagName)){const t=r.textContent.split(h),s=t.length-1;if(s>0){r.textContent=i?i.emptyScript:\"\";for(let i=0;i<s;i++)r.append(t[i],l()),C.nextNode(),d.push({type:2,index:++c});r.append(t[s],l())}}}else if(8===r.nodeType)if(r.data===o)d.push({type:2,index:c});else{let t=-1;for(;-1!==(t=r.data.indexOf(h,t+1));)d.push({type:7,index:c}),t+=h.length-1}c++}}static createElement(t,i){const s=r.createElement(\"template\");return s.innerHTML=t,s}}function S(t,i,s=t,e){if(i===T)return i;let h=void 0!==e?s._$Co?.[e]:s._$Cl;const o=c(i)?void 0:i._$litDirective$;return h?.constructor!==o&&(h?._$AO?.(!1),void 0===o?h=void 0:(h=new o(t),h._$AT(t,s,e)),void 0!==e?(s._$Co??=[])[e]=h:s._$Cl=h),void 0!==h&&(i=S(t,h._$AS(t,i.values),h,e)),i}class M{constructor(t,i){this._$AV=[],this._$AN=void 0,this._$AD=t,this._$AM=i}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(t){const{el:{content:i},parts:s}=this._$AD,e=(t?.creationScope??r).importNode(i,!0);C.currentNode=e;let h=C.nextNode(),o=0,n=0,l=s[0];for(;void 0!==l;){if(o===l.index){let i;2===l.type?i=new R(h,h.nextSibling,this,t):1===l.type?i=new l.ctor(h,l.name,l.strings,this,t):6===l.type&&(i=new z(h,this,t)),this._$AV.push(i),l=s[++n]}o!==l?.index&&(h=C.nextNode(),o++)}return C.currentNode=r,e}p(t){let i=0;for(const s of this._$AV)void 0!==s&&(void 0!==s.strings?(s._$AI(t,s,i),i+=s.strings.length-2):s._$AI(t[i])),i++}}class R{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(t,i,s,e){this.type=2,this._$AH=E,this._$AN=void 0,this._$AA=t,this._$AB=i,this._$AM=s,this.options=e,this._$Cv=e?.isConnected??!0}get parentNode(){let t=this._$AA.parentNode;const i=this._$AM;return void 0!==i&&11===t?.nodeType&&(t=i.parentNode),t}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(t,i=this){t=S(this,t,i),c(t)?t===E||null==t||\"\"===t?(this._$AH!==E&&this._$AR(),this._$AH=E):t!==this._$AH&&t!==T&&this._(t):void 0!==t._$litType$?this.$(t):void 0!==t.nodeType?this.T(t):u(t)?this.k(t):this._(t)}O(t){return this._$AA.parentNode.insertBefore(t,this._$AB)}T(t){this._$AH!==t&&(this._$AR(),this._$AH=this.O(t))}_(t){this._$AH!==E&&c(this._$AH)?this._$AA.nextSibling.data=t:this.T(r.createTextNode(t)),this._$AH=t}$(t){const{values:i,_$litType$:s}=t,e=\"number\"==typeof s?this._$AC(t):(void 0===s.el&&(s.el=N.createElement(P(s.h,s.h[0]),this.options)),s);if(this._$AH?._$AD===e)this._$AH.p(i);else{const t=new M(e,this),s=t.u(this.options);t.p(i),this.T(s),this._$AH=t}}_$AC(t){let i=A.get(t.strings);return void 0===i&&A.set(t.strings,i=new N(t)),i}k(t){a(this._$AH)||(this._$AH=[],this._$AR());const i=this._$AH;let s,e=0;for(const h of t)e===i.length?i.push(s=new R(this.O(l()),this.O(l()),this,this.options)):s=i[e],s._$AI(h),e++;e<i.length&&(this._$AR(s&&s._$AB.nextSibling,e),i.length=e)}_$AR(t=this._$AA.nextSibling,i){for(this._$AP?.(!1,!0,i);t&&t!==this._$AB;){const i=t.nextSibling;t.remove(),t=i}}setConnected(t){void 0===this._$AM&&(this._$Cv=t,this._$AP?.(t))}}class k{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(t,i,s,e,h){this.type=1,this._$AH=E,this._$AN=void 0,this.element=t,this.name=i,this._$AM=e,this.options=h,s.length>2||\"\"!==s[0]||\"\"!==s[1]?(this._$AH=Array(s.length-1).fill(new String),this.strings=s):this._$AH=E}_$AI(t,i=this,s,e){const h=this.strings;let o=!1;if(void 0===h)t=S(this,t,i,0),o=!c(t)||t!==this._$AH&&t!==T,o&&(this._$AH=t);else{const e=t;let n,r;for(t=h[0],n=0;n<h.length-1;n++)r=S(this,e[s+n],i,n),r===T&&(r=this._$AH[n]),o||=!c(r)||r!==this._$AH[n],r===E?t=E:t!==E&&(t+=(r??\"\")+h[n+1]),this._$AH[n]=r}o&&!e&&this.j(t)}j(t){t===E?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,t??\"\")}}class H extends k{constructor(){super(...arguments),this.type=3}j(t){this.element[this.name]=t===E?void 0:t}}class I extends k{constructor(){super(...arguments),this.type=4}j(t){this.element.toggleAttribute(this.name,!!t&&t!==E)}}class L extends k{constructor(t,i,s,e,h){super(t,i,s,e,h),this.type=5}_$AI(t,i=this){if((t=S(this,t,i,0)??E)===T)return;const s=this._$AH,e=t===E&&s!==E||t.capture!==s.capture||t.once!==s.once||t.passive!==s.passive,h=t!==E&&(s===E||e);e&&this.element.removeEventListener(this.name,this,s),h&&this.element.addEventListener(this.name,this,t),this._$AH=t}handleEvent(t){\"function\"==typeof this._$AH?this._$AH.call(this.options?.host??this.element,t):this._$AH.handleEvent(t)}}class z{constructor(t,i,s){this.element=t,this.type=6,this._$AN=void 0,this._$AM=i,this.options=s}get _$AU(){return this._$AM._$AU}_$AI(t){S(this,t)}}const Z={M:e,P:h,A:o,C:1,L:V,R:M,D:u,V:S,I:R,H:k,N:I,U:L,B:H,F:z},j=t.litHtmlPolyfillSupport;j?.(N,R),(t.litHtmlVersions??=[]).push(\"3.3.0\");const B=(t,i,s)=>{const e=s?.renderBefore??i;let h=e._$litPart$;if(void 0===h){const t=s?.renderBefore??null;e._$litPart$=h=new R(i.insertBefore(l(),t),t,void 0,s??{})}return h._$AI(t),h};export{Z as _$LH,x as html,w as mathml,T as noChange,E as nothing,B as render,b as svg};\n//# sourceMappingURL=lit-html.js.map\n","import{ReactiveElement as t}from\"@lit/reactive-element\";export*from\"@lit/reactive-element\";import{render as e,noChange as r}from\"lit-html\";export*from\"lit-html\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const s=globalThis;class i extends t{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){const t=super.createRenderRoot();return this.renderOptions.renderBefore??=t.firstChild,t}update(t){const r=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this._$Do=e(r,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this._$Do?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this._$Do?.setConnected(!1)}render(){return r}}i._$litElement$=!0,i[\"finalized\"]=!0,s.litElementHydrateSupport?.({LitElement:i});const o=s.litElementPolyfillSupport;o?.({LitElement:i});const n={_$AK:(t,e,r)=>{t._$AK(e,r)},_$AL:t=>t._$AL};(s.litElementVersions??=[]).push(\"4.2.0\");export{i as LitElement,n as _$LE};\n//# sourceMappingURL=lit-element.js.map\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t=t=>(e,o)=>{void 0!==o?o.addInitializer((()=>{customElements.define(t,e)})):customElements.define(t,e)};export{t as customElement};\n//# sourceMappingURL=custom-element.js.map\n","import{defaultConverter as t,notEqual as e}from\"../reactive-element.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const o={attribute:!0,type:String,converter:t,reflect:!1,hasChanged:e},r=(t=o,e,r)=>{const{kind:n,metadata:i}=r;let s=globalThis.litPropertyMetadata.get(i);if(void 0===s&&globalThis.litPropertyMetadata.set(i,s=new Map),\"setter\"===n&&((t=Object.create(t)).wrapped=!0),s.set(r.name,t),\"accessor\"===n){const{name:o}=r;return{set(r){const n=e.get.call(this);e.set.call(this,r),this.requestUpdate(o,n,t)},init(e){return void 0!==e&&this.C(o,void 0,t,e),e}}}if(\"setter\"===n){const{name:o}=r;return function(r){const n=this[o];e.call(this,r),this.requestUpdate(o,n,t)}}throw Error(\"Unsupported decorator location: \"+n)};function n(t){return(e,o)=>\"object\"==typeof o?r(t,e,o):((t,e,o)=>{const r=e.hasOwnProperty(o);return e.constructor.createProperty(o,t),r?Object.getOwnPropertyDescriptor(e,o):void 0})(t,e,o)}export{n as property,r as standardProperty};\n//# sourceMappingURL=property.js.map\n","import { css } from 'lit';\nimport * as Color from 'color';\n\nexport const COLORS = [\n  'primary',\n  'accent',\n  'red',\n  'pink',\n  'purple',\n  'deep-purple',\n  'indigo',\n  'blue',\n  'light-blue',\n  'cyan',\n  'teal',\n  'green',\n  'light-green',\n  'lime',\n  'yellow',\n  'amber',\n  'orange',\n  'deep-orange',\n  'brown',\n  'light-grey',\n  'grey',\n  'dark-grey',\n  'blue-grey',\n  'black',\n  'white',\n  'disabled',\n];\n\nexport function computeRgbColor(color: string): string {\n  if (color === 'primary' || color === 'accent') {\n    return `var(--rgb-${color}-color)`;\n  }\n  if (COLORS.includes(color)) {\n    return `var(--rgb-${color})`;\n  // eslint-disable-next-line no-else-return\n  } else if (color.startsWith('#')) {\n    try {\n      return Color.rgb(color).rgb().array().join(', ');\n    } catch (err) {\n      return '';\n    }\n  }\n  return color;\n}\n\nfunction capitalizeFirstLetter(string) {\n  return string.charAt(0).toUpperCase() + string.slice(1);\n}\n\nexport function computeColorName(color: string): string {\n  return color\n    .split('-')\n    .map((s) => capitalizeFirstLetter(s))\n    .join(' ');\n}\n\nexport const defaultColorCss = css`\n  --default-red: 244, 67, 54;\n  --default-pink: 233, 30, 99;\n  --default-purple: 146, 107, 199;\n  --default-deep-purple: 110, 65, 171;\n  --default-indigo: 63, 81, 181;\n  --default-blue: 33, 150, 243;\n  --default-light-blue: 3, 169, 244;\n  --default-cyan: 0, 188, 212;\n  --default-teal: 0, 150, 136;\n  --default-green: 76, 175, 80;\n  --default-light-green: 139, 195, 74;\n  --default-lime: 205, 220, 57;\n  --default-yellow: 255, 235, 59;\n  --default-amber: 255, 193, 7;\n  --default-orange: 255, 152, 0;\n  --default-deep-orange: 255, 111, 34;\n  --default-brown: 121, 85, 72;\n  --default-light-grey: 189, 189, 189;\n  --default-grey: 158, 158, 158;\n  --default-dark-grey: 96, 96, 96;\n  --default-blue-grey: 96, 125, 139;\n  --default-black: 0, 0, 0;\n  --default-white: 255, 255, 255;\n  --default-disabled: 189, 189, 189;\n`;\n\nexport const defaultDarkColorCss = css`\n  --default-disabled: 111, 111, 111;\n`;\n","export const logo: string = '%c WEATHER-CONDITION-CARD %c 2.0.0';\n\nexport const hacsImagePath: string = '/local/community/ha-card-weather-conditions/icons';\nexport const manImagePath: string = '/local/ha-card-weather-conditions/icons';\n\nexport const optConsoleParam1: string = 'color: white; background: green; font-weight: 700;';\nexport const optConsoleParam2: string = 'color: green; background: white; font-weight: 700;';\nexport const optConsoleParam3: string = 'color: black; background: white; font-weight: 700;';\n\nexport const iconTemperature: string = 'mdi:thermometer';\nexport const iconPrecipitation: string = 'mdi:weather-rainy';\n\nexport const cwcLocale = {\n  en: 0,\n  it: 1,\n  nl: 2,\n  es: 3,\n  de: 4,\n  fr: 5,\n  'sr-latn': 6,\n  pt: 7,\n  da: 8,\n  'no-no': 9,\n  cs: 10,\n  ru: 11,\n};\n\n// 🌑 🌒 🌓 🌔 🌕 🌖 🌗 🌘 🌑\nexport const cwcMoonPhaseIcons = {\n  new_moon: '🌑',\n  new: '🌑',\n  waxing_crescent: '🌒',\n  first_quarter: '🌓',\n  waxing_gibbous: '🌔',\n  full: '🌕',\n  full_moon: '🌕',\n  waning_gibbous: '🌖',\n  third_quarter: '🌗',\n  last_quarter: '🌗',\n  waning_crescent: '🌘',\n};\n","// clear=ok, partlycloudy=ok, cloudy=ok, partlycloudy-fog=ok, partlycloudy-light-rain=ok, partlycloudy-rain=ok,\n// light-rain=ok, rainy=ok, snowy-rainy=ok, partlycloudy-light-snow=ok, partlycloudy-snow=ok, light-snow=ok, snowy=ok,\n// partlycloudy-lightning=ok or lightning\n\nexport const cwcBuienradarDayIcons: { [key: string]: string; } = {\n  // freezing_rain_heavy: 'rainy-3',\n  // freezing_rain: 'rainy-2',\n  // freezing_rain_light: 'rainy-1',\n  // freezing_drizzle: 'rain-and-sleet-mix',\n  // ice_pellets_heavy: 'rain-and-snow-mix',\n  // ice_pellets: 'rain-and-snow-mix',\n  // ice_pellets_light: 'rain-and-snow-mix',\n  snowy: 'snowy-3',\n  'light-snow': 'snowy-2',\n  'snowy-rainy': 'snowy-1',\n  'partlycloudy-light-snow': 'snowy-1',\n  'partlycloudy-snow': 'snowy-1',\n  // flurries: 'wind',\n  // tstorm: 'tropical-storm',\n  // rain_heavy: 'rainy-3',\n  'partlycloudy-light-rain': 'rainy-1',\n  'light-rain': 'rainy-1',\n  rainy: 'rainy-2',\n  'partlycloudy-rain': 'rainy-1',\n  // fog_light: 'haze',\n  'partlycloudy-fog': 'fog',\n  cloudy: 'cloudy-original',\n  // mostly_cloudy: 'cloudy-day-3',\n  partlycloudy: 'cloudy-day-2',\n  'partlycloudy-lightning': 'cloudy-day-1',\n  lightning: 'cloudy-day-1',\n  // mostly_clear: 'cloudy-day-1',\n  clear: 'day',\n};\n\nexport const cwcBuienradarNightIcons: { [key: string]: string; } = {\n  ...cwcBuienradarDayIcons,\n  // freezing_rain_heavy: 'rainy-6',\n  // freezing_rain: 'rainy-5',\n  // freezing_rain_light: 'rainy-4',\n  // freezing_drizzle: 'rain-and-sleet-mix',\n  // ice_pellets_heavy: 'rain-and-snow-mix',\n  // ice_pellets: 'rain-and-snow-mix',\n  // ice_pellets_light: 'rain-and-snow-mix',\n  // snow_heavy: 'snowy-6',\n  // snow: 'nowy-5',\n  // snow_light: 'nowy-4',\n  // flurries: 'wind',\n  // tstorm: 'tropical-storm',\n  // rain_heavy: 'rainy-6',\n  // rain_light: 'rainy-4',\n  // rain: 'rainy-5',\n  // drizzle: 'rainy-4',\n  // fog_light: 'haze',\n  // fog: 'fog',\n  // cloudy: 'cloudy',\n  // mostly_cloudy: 'cloudy-night-3',\n  // partly_cloudy: 'cloudy-night-2',\n  // mostly_clear: 'cloudy-night-1',\n  // clear: 'night'\n};\n","export const cwcClimacellDayIcons: { [key: string]: string; } = {\n  freezing_rain_heavy: 'rainy-3',\n  'heavy freezing rain': 'rainy-3',\n  freezing_rain: 'rainy-2',\n  'freezing rain': 'rainy-2',\n  freezing_rain_light: 'rainy-1',\n  'light freezing rain': 'rainy-1',\n  freezing_drizzle: 'rain-and-sleet-mix',\n  'freezing drizzle': 'rain-and-sleet-mix',\n  ice_pellets_heavy: 'rain-and-snow-mix',\n  'heavy ice pellets': 'rain-and-snow-mix',\n  ice_pellets: 'rain-and-snow-mix',\n  'ice pellets': 'rain-and-snow-mix',\n  ice_pellets_light: 'rain-and-snow-mix',\n  'light ice pellets': 'rain-and-snow-mix',\n  snow_heavy: 'snowy-3',\n  'heavy snow': 'snowy-3',\n  snow: 'snowy-2',\n  snow_light: 'snowy-1',\n  'light snow': 'snowy-1',\n  flurries: 'wind',\n  tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-3',\n  'heavy rain': 'rainy-3',\n  rain_light: 'rainy-1',\n  'light rain': 'rainy-1',\n  rain: 'rainy-2',\n  drizzle: 'rainy-1',\n  fog_light: 'haze',\n  'light fog': 'haze',\n  fog: 'fog',\n  cloudy: 'cloudy-original',\n  mostly_cloudy: 'cloudy-day-3',\n  'mostly cloudy': 'cloudy-day-3',\n  partly_cloudy: 'cloudy-day-2',\n  'partly cloudy': 'cloudy-day-2',\n  mostly_clear: 'cloudy-day-1',\n  'mostly clear': 'cloudy-day-1',\n  clear: 'day',\n};\n\nexport const cwcClimacellNightIcons: { [key: string]: string; } = {\n  ...cwcClimacellDayIcons,\n  freezing_rain_heavy: 'rainy-6',\n  'heavy freezing rain': 'rainy-6',\n  freezing_rain: 'rainy-5',\n  'freezing rain': 'rainy-5',\n  freezing_rain_light: 'rainy-4',\n  'light freezing rain': 'rainy-4',\n  // freezing_drizzle: 'rain-and-sleet-mix',\n  // ice_pellets_heavy: 'rain-and-snow-mix',\n  // ice_pellets: 'rain-and-snow-mix',\n  // ice_pellets_light: 'rain-and-snow-mix',\n  snow_heavy: 'snowy-6',\n  'heavy snow': 'snowy-6',\n  snow: 'snowy-5',\n  snow_light: 'snowy-4',\n  'light snow': 'snowy-4',\n  // flurries: 'wind',\n  // tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-6',\n  'heavy rain': 'rainy-6',\n  rain_light: 'rainy-4',\n  'light rain': 'rainy-4',\n  rain: 'rainy-5',\n  drizzle: 'rainy-4',\n  // fog_light: 'haze',\n  // fog: 'fog',\n  // cloudy: 'cloudy',\n  mostly_cloudy: 'cloudy-night-3',\n  'mostly cloudy': 'cloudy-night-3',\n  partly_cloudy: 'cloudy-night-2',\n  'partly cloudy': 'cloudy-night-2',\n  mostly_clear: 'cloudy-night-1',\n  'mostly clear': 'cloudy-night-1',\n  clear: 'night',\n  sunny: 'night',\n};\n\nexport const cwcClimacellDayBg: { [key: string]: string; } = {\n  freezing_rain_heavy: 'rainy-3',\n  freezing_rain: 'rainy-2',\n  freezing_rain_light: 'rainy-1',\n  freezing_drizzle: 'rain-and-sleet-mix',\n  ice_pellets_heavy: 'rain-and-snow-mix',\n  ice_pellets: 'rain-and-snow-mix',\n  ice_pellets_light: 'rain-and-snow-mix',\n  snow_heavy: 'snowy-3',\n  snow: 'snowy-2',\n  snow_light: 'snowy-1',\n  flurries: 'wind',\n  tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-3',\n  rain_light: 'rainy-1',\n  rain: 'rainy-2',\n  drizzle: 'rainy-1',\n  fog_light: 'haze',\n  fog: 'fog',\n  cloudy: 'cloudy-original',\n  mostly_cloudy: 'day-cloud-3.jpg',\n  partly_cloudy: 'day-cloud-2.jpg',\n  mostly_clear: 'day-cloud-1.jpg',\n  clear: 'day-clear.jpg',\n};\n","export const cwcDarkskyDayIcons: { [key: string]: string; } = {\n  clear: 'day',\n  'clear-day': 'day',\n  rain: 'rainy-2',\n  snow: 'snowy-2',\n  sleet: 'rain-and-sleet-mix',\n  wind: 'cloudy-day-1',\n  fog: 'fog',\n  cloudy: 'cloudy-original',\n  'partly-cloudy-day': 'cloudy-day-2',\n};\n\nexport const cwcDarkskyNightIcons: { [key: string]: string; } = {\n  ...cwcDarkskyDayIcons,\n  clear: 'night',\n  'clear-night': 'night',\n  wind: 'cloudy-night-1',\n  'partly-cloudy-day': 'cloudy-night-2',\n  'partly-cloudy-night': 'cloudy-night-2',\n};\n","export const cwcDefaultHassDayIcons: { [key: string]: string } = {\n  cloudy: 'cloudy-day-3',\n  exceptional: 'severe-thunderstorm',\n  fog: 'fog',\n  hail: 'snow-and-sleet-mix',\n  lightning: 'severe-thunderstorm',\n  'lightning-rainy': 'scattered-thunderstorms',\n  partlycloudy: 'cloudy-day-3',\n  pouring: 'rainy-6',\n  rainy: 'rainy-5',\n  snowy: 'snowy-6',\n  'snowy-rainy': 'snow-and-sleet-mix',\n  sunny: 'clear-day',\n  windy: 'wind',\n  'windy-variant': 'wind',\n};\n\nexport const cwcDefaultHassNightIcons: { [key: string]: string } = {\n  ...cwcDefaultHassDayIcons,\n  'clear-night': 'clear-night',\n};\n","export const cwcOpenWeatherMapDayIcons: { [key: string]: string; } = {\n  'clear sky': 'day',\n  'few clouds': 'cloudy-day-1',\n  'scattered clouds': 'cloudy-day-2',\n  'broken clouds': 'cloudy-day-3',\n  'shower rain': 'rainy-3',\n  rain: 'rainy-2',\n  thunderstorm: 'tropical-storm',\n  snow: 'snowy-2',\n  mist: 'fog',\n};\n\nexport const cwcOpenWeatherMapNightIcons: { [key: string]: string; } = {\n  ...cwcOpenWeatherMapDayIcons,\n  'clear sky': 'day-night',\n  'few clouds': 'cloudy-night-1',\n  'scattered clouds': 'cloudy-night-2',\n  'broken clouds': 'cloudy-night-3',\n};\n","// Pirate Weather Icons\n// clear-day, clear-night, rain, snow, sleet, wind, fog, cloudy, partly-cloudy-day and partly-cloudy-night\n// mostly-clear-day, mostly-clear-night, mostly-cloudy-day, mostly-cloudy-night, possible-rain-day, possible-rain-night\n// possible-snow-day, possible-snow-night, possible-sleet-day, possible-sleet-night, possible-precipitation-day\n// possible-precipitation-night, precipitation, drizzle, light-rain, heavy-rain, flurries, light-snow, heavy-snow\n// very-light-sleet, light-sleet, heavy-sleet, breezy, dangerous-wind\n\nexport const cwcDaytimePirateWeatherIcons: { [key: string]: string; } = {\n  freezing_rain_heavy: 'rainy-3',\n  'heavy freezing rain': 'rainy-3',\n  freezing_rain: 'rainy-2',\n  'freezing rain': 'rainy-2',\n  freezing_rain_light: 'rainy-1',\n  'light freezing rain': 'rainy-1',\n  freezing_drizzle: 'rain-and-sleet-mix',\n  sleet: 'rain-and-sleet-mix',\n  'freezing drizzle': 'rain-and-sleet-mix',\n  ice_pellets_heavy: 'rain-and-snow-mix',\n  'heavy ice pellets': 'rain-and-snow-mix',\n  ice_pellets: 'rain-and-snow-mix',\n  'ice pellets': 'rain-and-snow-mix',\n  ice_pellets_light: 'rain-and-snow-mix',\n  'light ice pellets': 'rain-and-snow-mix',\n  snow_heavy: 'snowy-3',\n  'heavy snow': 'snowy-3',\n  snow: 'snowy-2',\n  snow_light: 'snowy-1',\n  'light snow': 'snowy-1',\n  flurries: 'wind',\n  tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-3',\n  'heavy rain': 'rainy-3',\n  rain_light: 'rainy-1',\n  rainy: 'rainy-1',\n  'light rain': 'rainy-1',\n  rain: 'rainy-2',\n  drizzle: 'rainy-1',\n  fog_light: 'haze',\n  'light fog': 'haze',\n  fog: 'fog',\n  cloudy: 'cloudy-original',\n  mostly_cloudy: 'cloudy-day-3',\n  'mostly cloudy': 'cloudy-day-3',\n  partly_cloudy: 'cloudy-day-2',\n  partlycloudy: 'cloudy-day-2',\n  'partly-cloudy-day': 'cloudy-day-2',\n  'partly cloudy': 'cloudy-day-2',\n  mostly_clear: 'cloudy-day-1',\n  'mostly clear': 'cloudy-day-1',\n  clear: 'day',\n  'clear-day': 'day',\n  wind: 'wind',\n  windy: 'wind',\n  sunny: 'day',\n  'clear-night': 'day',\n};\n\nexport const cwcNightlyPirateWeaterIcons: { [key: string]: string; } = {\n  ...cwcDaytimePirateWeatherIcons,\n  freezing_rain_heavy: 'rainy-6',\n  'heavy freezing rain': 'rainy-6',\n  freezing_rain: 'rainy-5',\n  'freezing rain': 'rainy-5',\n  freezing_rain_light: 'rainy-4',\n  'light freezing rain': 'rainy-4',\n  // freezing_drizzle: 'rain-and-sleet-mix',\n  // ice_pellets_heavy: 'rain-and-snow-mix',\n  // ice_pellets: 'rain-and-snow-mix',\n  // ice_pellets_light: 'rain-and-snow-mix',\n  snow_heavy: 'snowy-6',\n  'heavy snow': 'snowy-6',\n  snow: 'snowy-5',\n  snow_light: 'snowy-4',\n  'light snow': 'snowy-4',\n  // flurries: 'wind',\n  // tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-6',\n  'heavy rain': 'rainy-6',\n  rain_light: 'rainy-4',\n  'light rain': 'rainy-4',\n  rain: 'rainy-5',\n  drizzle: 'rainy-4',\n  // fog_light: 'haze',\n  // fog: 'fog',\n  // cloudy: 'cloudy',\n  mostly_cloudy: 'cloudy-night-3',\n  'mostly cloudy': 'cloudy-night-3',\n  partly_cloudy: 'cloudy-night-2',\n  partlycloudy: 'cloudy-night-2',\n  'partly-cloudy-night': 'cloudy-night-2',\n  'partly cloudy': 'cloudy-night-2',\n  mostly_clear: 'cloudy-night-1',\n  'mostly clear': 'cloudy-night-1',\n  clear: 'night',\n  'clear-night': 'night',\n  sunny: 'night',\n};\n","import { cwcBuienradarDayIcons, cwcBuienradarNightIcons } from '../src/iconmodels/im-buienradar';\nimport { cwcClimacellDayIcons, cwcClimacellNightIcons } from '../src/iconmodels/im-climacell';\nimport { cwcDarkskyDayIcons, cwcDarkskyNightIcons } from '../src/iconmodels/im-darksky';\nimport { cwcDefaultHassDayIcons, cwcDefaultHassNightIcons } from '../src/iconmodels/im-hass';\nimport { cwcOpenWeatherMapDayIcons, cwcOpenWeatherMapNightIcons } from '../src/iconmodels/im-openweathermap';\nimport { cwcDaytimePirateWeatherIcons, cwcNightlyPirateWeaterIcons } from '../src/iconmodels/im-pirateweather';\n\nexport interface AlertItem {\n  entity: string\n  icon?: string ;\n  min?: number ;\n  max?: number ;\n  show_if_on?: boolean ;\n  show_if_ge?: number ;\n}\n\nexport interface PollenItem {\n  entity: string ;\n  icon?: string ;\n  min: number ;\n  max: number ;\n  low?: number ;\n  high?: number ;\n}\n\nexport interface Pollen {\n  tree?: PollenItem ;\n  weed?: PollenItem ;\n  grass?: PollenItem ;\n}\n\nexport interface AirQuality {\n  pm25?: string ;\n  pm10?: string ;\n  o3?: string ;\n  no2?: string ;\n  co?: string ;\n  so2?: string ;\n  epa_aqi?: string ;\n  epa_primary_pollutant?: string ;\n  epa_health_concern?: string ;\n}\n\nexport interface Uv {\n  protection_window?: string ;\n  ozone_level?: string ;\n  uv_index?: string ;\n  uv_level?: string ;\n  max_uv_index?: string ;\n  set_skin_type_1?: string ;\n  set_skin_type_2?: string ;\n  set_skin_type_3?: string ;\n  set_skin_type_4?: string ;\n  set_skin_type_5?: string ;\n  set_skin_type_6?: string ;\n}\n\nexport interface Days {\n  day_1: string ;\n  day_2: string ;\n  day_3: string ;\n  day_4: string ;\n  day_5: string ;\n  day_6: string ;\n}\n\nexport interface Current {\n  sun?: string ;\n  moon_phase?: string ;\n  // daily_summary?: string ;\n  current_conditions?: string\n  humidity?: string ;\n  pressure?: string ;\n  temperature?: string ;\n  feels_like?: string ;\n  visibility?: string ;\n  wind_bearing?: string ;\n  wind_speed?: string ;\n  precipitation?: string ;\n  forecast?: boolean ;\n}\nexport interface Forecast {\n  meteogram?: string ;\n  temperature_high?: Days ;\n  temperature_low?: Days ;\n  summary?: Days ;\n  icons?: Days ;\n  precipitation_probability?: Days ;\n  precipitation_intensity?: Days ;\n}\n\nexport interface Weather {\n  icons_model: string ;\n  current: Current ;\n  forecast?: Forecast ;\n}\n\nexport interface Hours {\n  hour_1: string ;\n  hour_2: string ;\n  hour_3: string ;\n  hour_4: string ;\n  hour_5: string ;\n  hour_6: string ;\n}\n\nexport interface IconsConfig {\n  path: string ;\n  iconType: string ;\n  icons_model: string ;\n  iconsDay: { [key: string]: string; } ;\n  iconsNight: { [key: string]: string; } ;\n}\n\nexport interface ITerms {\n   windDirections;\n   words;\n}\n\nexport interface Alert {\n  fire_risk?: AlertItem ;\n  thunderstorms_risk?: AlertItem ;\n  hydraulic_risk?: AlertItem ;\n  hydrogeological_risk?: AlertItem ;\n}\n\nexport interface Sea {\n  swell_direction?: Hours ;\n  swell_height?: Hours ;\n  swell_period?: Hours ;\n  wind_direction: Hours ;\n  wind_speed: Hours ;\n  air_temperature: Hours ;\n  water_temperature: Hours ;\n}\n\nexport interface CardConfig {\n  type: string ;\n  name?: string ;\n  language?: string ;\n  animation?: boolean ;\n  display: string[]\n  uv?: Uv ;\n  air_quality?: AirQuality ;\n  pollen?: Pollen ;\n  weather: Weather ;\n  camera?: string ;\n  alert: Alert ;\n  sea: Sea ;\n}\n\nexport interface IconsModelConfig {\n  iconsDay: Record<string, string>;\n  iconsNight: Record<string, string>;\n}\n\nexport const iconsModels: Record<string, IconsModelConfig> = {\n  pirateweather: {\n    iconsDay: cwcDaytimePirateWeatherIcons,\n    iconsNight: cwcNightlyPirateWeaterIcons,\n  },\n  climacell: {\n    iconsDay: cwcClimacellDayIcons,\n    iconsNight: cwcClimacellNightIcons,\n  },\n  darksky: {\n    iconsDay: cwcDarkskyDayIcons,\n    iconsNight: cwcDarkskyNightIcons,\n  },\n  openweathermap: {\n    iconsDay: cwcOpenWeatherMapDayIcons,\n    iconsNight: cwcOpenWeatherMapNightIcons,\n  },\n  buienradar: {\n    iconsDay: cwcBuienradarDayIcons,\n    iconsNight: cwcBuienradarNightIcons,\n  },\n  defaulthass: {\n    iconsDay: cwcDefaultHassDayIcons,\n    iconsNight: cwcDefaultHassNightIcons,\n  },\n};\n","/* eslint-disable camelcase */\nimport { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iconsModels } from '../../backup/types';\n\nexport interface IconsConfigResult {\n  iconsModel: string;\n  iconsDay: Record<string, string>;\n  iconsNight: Record<string, string>;\n}\n\n// export const getEntityState = (hass: HomeAssistant, entityId?: string) => (\n//   entityId ? hass.states[entityId]?.state : undefined\n// );\n\n/**\n * Restituisce la traduzione di un termine usando un dizionario, in modo case-insensitive.\n * Se il termine non è trovato, restituisce l'originale.\n */\nexport const translate = (term: string, dictionary: Record<string, string>): string => {\n  const key = Object.keys(dictionary).find((k) => k.toLowerCase() === term.toLowerCase());\n  return key ? dictionary[key] : term;\n};\n\ntype LocaleInfo = {\n  locale: string;\n  timezone: string;\n  cwc?: number;\n};\n\nexport const getLocaleInfo = (lang: string): LocaleInfo => {\n  const localeMap: Record<string, string> = {\n    en: 'en-US',\n    it: 'it-IT',\n    nl: 'nl-NL',\n    es: 'es-ES',\n    de: 'de-DE',\n    fr: 'fr-FR',\n    'sr-latn': 'sr-Latn',\n    pt: 'pt-PT',\n    da: 'da-DK',\n    'no-no': 'nb-NO',\n    cs: 'cs-CZ',\n    ru: 'ru-RU',\n  };\n\n  const timezoneMap: Record<string, string> = {\n    en: 'America/New_York',\n    it: 'Europe/Rome',\n    nl: 'Europe/Amsterdam',\n    es: 'Europe/Madrid',\n    de: 'Europe/Berlin',\n    fr: 'Europe/Paris',\n    'sr-latn': 'Europe/Belgrade',\n    ja: 'Asia/Tokyo',\n    pt: 'Europe/Lisbon',\n    da: 'Europe/Copenhagen',\n    'no-no': 'Europe/Oslo',\n    cs: 'Europe/Prague',\n    ru: 'Europe/Moscow',\n  };\n\n  const cwcLocale: Record<string, number> = {\n    en: 0,\n    it: 1,\n    nl: 2,\n    es: 3,\n    de: 4,\n    fr: 5,\n    'sr-latn': 6,\n    pt: 7,\n    da: 8,\n    'no-no': 9,\n    cs: 10,\n    ru: 11,\n  };\n\n  return {\n    locale: localeMap[lang] || lang,\n    timezone: timezoneMap[lang] || 'UTC',\n    ...(lang in cwcLocale && { cwc: cwcLocale[lang] }),\n  };\n};\n\nexport const getLocale = (lang: string) => {\n  const map = {\n    it: 'it-IT',\n    en: 'en-US',\n    fr: 'fr-FR',\n    de: 'de-DE',\n    es: 'es-ES',\n    ja: 'ja-JP',\n    zh: 'zh-CN',\n    // Aggiungi altri se servono\n  };\n  return map[lang] || `${lang}-${lang.toUpperCase()}`; // fallback generico\n};\n\nexport const getFormatter = (\n  locale: string = 'en-US',\n  fractionDigits: number = 1,\n  useGrouping: boolean = false,\n): Intl.NumberFormat => new Intl.NumberFormat(locale, {\n  minimumFractionDigits: fractionDigits,\n  maximumFractionDigits: fractionDigits,\n  useGrouping,\n});\n\nexport const formatNumber = (\n  {\n    stringNumber,\n    lang = 'en',\n    fractionDigits = 1,\n    useGrouping = false,\n  }: {\n    stringNumber: string;\n    lang?: string;\n    fractionDigits?: number;\n    useGrouping?: boolean;\n  },\n): string => {\n  const number = parseFloat(stringNumber);\n  if (Number.isNaN(number)) return '';\n\n  const effectiveFormatter = getFormatter(getLocale(lang), fractionDigits, useGrouping);\n  // console.debug(`>>>|| ${number} ${effectiveFormatter.format(number)}`);\n  return effectiveFormatter.format(number);\n};\n\nexport const getIconModelData = (iconsModel: string): IconsConfigResult => {\n  const modelName = iconsModel.toLowerCase() ?? 'climacell';\n\n  if (modelName in iconsModels) {\n    const { iconsDay, iconsNight } = iconsModels[modelName];\n    return {\n      iconsModel: modelName,\n      iconsDay,\n      iconsNight,\n    };\n  }\n\n  console.warn(`Unknown icons model: ${modelName}. Falling back to 'climacell'.`);\n\n  const fallback = iconsModels['climacell'];\n  return {\n    iconsModel: 'climacell',\n    iconsDay: fallback.iconsDay,\n    iconsNight: fallback.iconsNight,\n  };\n};\n\nexport function pad(n: number | string, width: number, z = '0'): string {\n  return n.toString().padStart(width, z);\n}\n\n/**\n * Converte una stringa numerica localizzata in un numero.\n * Esempio: '1.234,56' (it-IT) → 1234.56\n * @param input - La stringa o numero da convertire.\n * @param locale - Il locale da utilizzare per determinare i separatori.\n * @returns Il numero convertito o NaN se la conversione fallisce.\n */\nexport const string2Number = (input: string | number, locale: string = 'en-US'): number => {\n  if (typeof input === 'number') return input;\n\n  const formatter = new Intl.NumberFormat(locale);\n  const parts = formatter.formatToParts(1234567.89);\n\n  const group = parts.find((part) => part.type === 'group')?.value || '';\n  const decimal = parts.find((part) => part.type === 'decimal')?.value || '.';\n\n  // Rimuove i separatori delle migliaia e sostituisce il separatore decimale con '.'\n  const normalized = input\n    .replace(new RegExp(`\\\\${group}`, 'g'), '')\n    .replace(new RegExp(`\\\\${decimal}`), '.');\n\n  return Number(normalized);\n};\n\nexport const getEntityRawValue = (hass: HomeAssistant, entityId?: string): string | undefined => (\n  entityId && hass.states[entityId]?.state\n);\n\nexport const getEntityRawAttribute = (hass: HomeAssistant, entityId: string, attribute: string): string | undefined => (\n  entityId && hass.states[entityId]?.attributes[attribute]\n);\n\nexport const getEntityNumericValue = (\n  {\n    entityId,\n    hass,\n    lang = 'en',\n    decimals = 0,\n  }: {\n    entityId?: string;\n    hass?: HomeAssistant;\n    lang?: string;\n    decimals?: number;\n  } = {},\n): string | undefined => {\n  const state = hass && entityId && hass.states[entityId]?.state;\n  return state !== undefined ? formatNumber({ stringNumber: state, fractionDigits: decimals, lang }) : undefined;\n};\n\nexport const getEntityUnit = (hass: HomeAssistant, entityId?: string): string | undefined => (\n  entityId && hass.states[entityId]?.attributes?.unit_of_measurement\n);\n\nexport const getEntityIcon = (hass: HomeAssistant, entityId?: string): string | undefined => (\n  entityId && hass.states[entityId]?.attributes?.icon\n);\n\nexport const getWindDirections = (\n  wd: number | string,\n  cwcLocWindDirections,\n): string | null => {\n  const wdNumber = typeof wd === 'number' ? wd : parseFloat(wd);\n\n  if (Number.isNaN(wdNumber)) {\n    return cwcLocWindDirections[wd] ?? null;\n  }\n\n  if (wdNumber < 0 || wdNumber > 360) {\n    console.error(`Invalid wind direction: '${wd}'. Valid values are between 0 and 360 degrees.`);\n    return null;\n  }\n\n  const directions = [\n    'N', 'NNE', 'NE', 'ENE', 'E', 'ESE',\n    'SE', 'SSE', 'S', 'SSW', 'SW', 'WSW',\n    'W', 'WNW', 'NW', 'NNW',\n  ];\n\n  const index = Math.floor(((wdNumber + 11.25) % 360) / 22.5);\n\n  const dirKey = directions[index];\n\n  return cwcLocWindDirections[dirKey] ?? null;\n};\n\nexport function imageExist(imageSrc: string, timeout = 5000): Promise<boolean> {\n  return new Promise<boolean>((resolve) => {\n    const img = new Image();\n    const timer = setTimeout(() => {\n      img.src = ''; // forza stop\n      resolve(false);\n    }, timeout);\n\n    img.onload = () => {\n      clearTimeout(timer);\n      resolve(true);\n    };\n    img.onerror = () => {\n      clearTimeout(timer);\n      resolve(false);\n    };\n    img.src = imageSrc;\n  });\n}\n\nexport async function loadJSON(full_path_file: string): Promise<string> {\n  try {\n    const response = await fetch(full_path_file);\n    if (!response.ok) {\n      const err = `ERROR retrieving JSON file: '${full_path_file}', status: ${response.status} ${response.statusText}`;\n      console.info(err);\n      throw new Error(err);\n    }\n    console.info(`Locale '${full_path_file}' loaded`);\n    return await response.text();\n  } catch (error) {\n    console.info(`Fetch failed for '${full_path_file}':`, error);\n    throw error;\n  }\n}\n\nexport function logInfo(message: string, ...styles: unknown[]) {\n  console.info(message, ...(styles.length ? styles : []));\n}\n\nexport function parseLocalizedNumber(value: string | number, locale = 'en-US'): number {\n  if (typeof value === 'number') return value;\n\n  // Semplificazione solo per 'it-IT': usa virgola come separatore decimale\n  const normalized = value.replace(/\\./g, '').replace(',', '.');\n  return Number(normalized);\n}\n","// eslint-disable-next-line object-curly-newline\nexport const cwcLocale = { en: 0, it: 1, nl: 2, es: 3, de: 4, fr: 5, 'sr-latn': 6, pt: 7, da: 8, 'no-no': 9, cs: 10 };\n\n// export let cwcLocWindDirections = {\n//   'N': ['N', 'N', 'N', 'N', 'N', 'N', 'S'],\n//   'NNE': ['NNE', 'NNE', 'NNO', 'NNE', 'NNO', 'NNE', 'SSI'],\n//   'NE': ['NE', 'NE', 'NO', 'NE', 'NO', 'NE', 'SI'],\n//   'ENE': ['ENE', 'ENE', 'ONO', 'ENE', 'ONO', 'ENE', 'ISI'],\n//   'E': ['E', 'E', 'O', 'E', 'O', 'E', 'I'],\n//   'ESE': ['ESE', 'ESE', 'OZO', 'ESE', 'OSO', 'ESE', 'IJI'],\n//   'SE': ['SE', 'SE', 'ZO', 'SE', 'SO', 'SE', 'JI'],\n//   'SSE': ['SSE', 'SSE', 'ZZO', 'SSE', 'SSO', 'SSE', 'JJI'],\n//   'S': ['S', 'S', 'Z', 'S', 'S', 'S', 'J'],\n//   'SSW': ['SSW', 'SSO', 'ZZW', 'SSO', 'SSW', 'SSO', 'JJZ'],\n//   'SW': ['SW', 'SO', 'ZW', 'SO', 'SW', 'SO', 'JZ'],\n//   'WSW': ['WSW', 'OSO', 'WZW', 'OSO', 'WSW', 'OSO', 'ZSZ'],\n//   'W': ['W', 'O', 'W', 'O', 'W', 'O', 'Z'],\n//   'WNW': ['WNW', 'ONO', 'WNW', 'ONO', 'WNW', 'ONO', 'ZSZ'],\n//   'NW': ['NW', 'NO', 'NW', 'NO', 'NW', 'NO', 'SZ'],\n//   'NNW': ['NNW', 'NNO', 'NNW', 'NNO', 'NNW', 'NNO', 'SSZ'],\n// };\n\n// export let cwcTerms = {\n//   'Feels Like' : ['Feels Like', 'Percepita', 'Voelt Als', 'Parece que', 'Gef&uuml;hlt',\n//     'Ressentie', 'Subjektivni osećaj'],\n//   'new_moon': [ 'New moon', 'Novilunio', 'Nieuwe maan', 'Luna nueva', 'Neumond',\n//     'Nouvelle lune', 'Mlad mesec'],\n//   'new': [ 'New moon', 'Novilunio', 'Nieuwe maan', 'Luna nueva', 'Neumond',\n//     'Nouvelle lune', 'Mlad mesec'],\n//   'waxing_crescent': ['Waxing crescent', 'Luna crescente', 'Wassende sikkel', 'Media luna de cera', 'Zunehmende Sichel',\n//     'Premier croissant', 'Prva osmina'],\n//   'first_quarter': ['First quarter', 'Primo Quarto', 'Eerste kwartaal', 'Primer trimestre', 'Erstes Viertel',\n//     'Premier quartier', 'Prva četvrt'],\n//   'waxing_gibbous': ['Waxing Gibbous', 'Gibbosa crescente', 'Wassen Gibbous', 'Encerado Gibbous', 'Zunehmender Halbmond',\n//     'Gibbeuse croissante', 'Treća osmina'],\n//   'full': ['Full', 'Luna piena', 'Volledig', 'Completo', 'Vollmond',\n//     'Pleine lune', 'Pun mesec'],\n//   'waning_gibbous': ['Waning Gibbous', 'Gibbosa calante', 'Zwemmende Gibbous', 'Waning Gibbous', 'Abnehmender Halbmond',\n//     'Gibbeuse décroissante', 'Peta osmina'],\n//   'third_quarter': ['Third Quarter', 'Ultimo quarto', 'Derde Kwartier', 'Tercer cuarto', 'Drittes Viertel',\n//     'Dernier quartier', 'Treća četvrtina'],\n//   'last_quarter': ['Last Quarter', 'Ultimo quarto', 'Laatste Kwartier', 'Último cuarto', 'Letztes Viertel',\n//     'Dernier quartier', 'Zadnja četvrtina'],\n//   'waning_crescent': ['Waning Crescent', 'Luna calante', 'Zwemmende sikkel', 'Waning Crescent', 'Abnehmende Sichel',\n//     'Lune décroissante', 'Sedma osmina'],\n// } ;\n\n// 🌑 🌒 🌓 🌔 🌕 🌖 🌗 🌘 🌑\nexport const cwcMoonPhaseIcons = {\n  new_moon: '🌑',\n  new: '🌑',\n  waxing_crescent: '🌒',\n  first_quarter: '🌓',\n  waxing_gibbous: '🌔',\n  full: '🌕',\n  full_moon: '🌕',\n  waning_gibbous: '🌖',\n  third_quarter: '🌗',\n  last_quarter: '🌗',\n  waning_crescent: '🌘',\n};\n","import { css } from 'lit';\n\nconst cardStyle = css`\n  ha-card {\n    cursor: pointer;\n    position: relative;\n    width: 100%;\n  }\n\n  .ha-card-weather-conditions {\n    width: 100%;\n    box-sizing: border-box;\n    background-color: var(--card-background-color, #1c1c1c);\n    color: var(--primary-text-color, #ffffff);\n    border-radius: var(--ha-card-border-radius, 12px);\n    box-shadow: var(--ha-card-box-shadow, 0 2px 6px rgba(0, 0, 0, 0.2));\n    overflow: hidden;\n    padding: 0;\n    display: flex;\n    flex-direction: column;\n  }\n\n  .nd-container {\n    width: 100%;\n    box-sizing: border-box;\n    display: flex;\n    flex-direction: column;\n    padding: 16px 20px; /* ← padding orizzontale più ampio */\n    gap: 12px;\n    background-size: cover;\n    background-position: center;\n    transition: background-image 0.3s ease-in-out;\n  }\n\n  /* Esempio di stile dinamico aggiuntivo se habgImage è una classe */\n  .nd-container.sunny {\n    background-image: url('/local/images/sunny-bg.jpg');\n  }\n\n  .nd-container.rainy {\n    background-image: url('/local/images/rainy-bg.jpg');\n  }\n\n  /* -------------- */\n\n`;\n\nexport default cardStyle;\n","import { css } from 'lit';\n\nconst summaryStyle = css`\n\n.summary-grid-container {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: 1fr 1fr 1fr; /* <-- 3 colonne reali */\n  grid-template-rows: auto auto;\n  width: 100%;\n  max-width: 600px;\n  // background: #1c1c1c;\n  // color: white;\n  gap: 4px;\n  padding: 0px;\n  box-sizing: border-box;\n  // border: 1px solid #444; /* debug */\n}\n\n.summary-col-left {\n  grid-column: 1;\n  grid-row: 1 / span 2;\n  // background: #2c2c2c;\n  padding-top: 0px;\n  padding-right: 0px;\n  padding-bottom: 0px;\n  padding-left: 0px;\n  \n  display: flex;                 /* Attiva Flexbox */\n  justify-content: center;      /* Centra orizzontalmente */\n  align-items: center;          /* Centra verticalmente */\n\n  width: 100%;\n  max-width: 100%;\n  aspect-ratio: 1 / 1; /* opzionale: mantiene forma quadrata */\n  overflow: hidden;\n}\n\n.summary-top-right {\n  grid-column: 2 / span 2; /* occupa colonne 2 e 3 */\n  grid-row: 1;\n  // background: #3c3c3c;\n  padding-top: 0px;\n  padding-right: 8px;\n  padding-bottom: 0px;\n  padding-left: 8px;\n  display: flex;            /* aggiunto */\n  align-items: center;      /* centra verticalmente */\n  justify-content: flex-start; /* allinea a sinistra */\n}\n\n.summary-bottom-right-left {\n  grid-column: 2;\n  grid-row: 2;\n  // background: #4c4c4c;\n  padding-top: 0px;\n  padding-right: 8px;\n  padding-bottom: 0px;\n  padding-left: 8px;\n\n  display: flex;                 /* Attiva Flexbox */\n  justify-content: center;      /* Centra orizzontalmente */\n  align-items: center;          /* Centra verticalmente */\n}\n\n.summary-bottom-right-right {\n  grid-column: 3;\n  grid-row: 2;\n  // background: #5c5c5c;\n  padding-top: 0px;\n  padding-right: 8px;\n  padding-bottom: 0px;\n  padding-left: 8px;\n}\n\n.weather-condition-icon {\n  width: 100%;\n  height: auto;\n  max-width: 100%;\n  max-height: 100%;\n  object-fit: contain;\n  // max-width: 100%;\n  // max-height: 100%;\n  // width: 72px;\n  // height: 72px;\n  // object-fit: contain;\n\n  transition: transform 0.2s ease;\n}\n  \n.summary-col-left:hover .weather-condition-icon {\n  transform: scale(1.05);\n}\n\n.weather-city-name {\n  font-size: clamp(1em, 2vw, 1.2em);\n  text-align: left;\n}\n\n.moon-row {\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  // font-size: 0.95em;\n  // color: #eeeeee;\n}\n\n.summary-moon-icon {\n  font-size: 1.8em;\n  display: inline-block;\n}\n\n.temperature-block {\n  display: flex;\n  flex-direction: column;\n  align-items: flex-end;\n  text-align: right;\n}\n\n.temperature {\n  font-size: 1.6em;\n  font-weight: bold;\n}\n\n.temp-unit {\n  font-size: 0.95em;\n  vertical-align: super;\n  margin-left: 2px;\n}\n\n.feels-like {\n  font-size: 0.85em;\n  // color: #aaaaaa;\n}\n\n.summary-wrapper {\n  position: relative;\n  width: 100%;\n  height: 100%;\n  min-height: 100px; /* oppure clamp() dinamico */\n  overflow: visible;\n}\n\n.lightning-background {\n  position: absolute;\n  inset: 0; /* top: 0; right: 0; bottom: 0; left: 0 */\n  pointer-events: none;\n  z-index: 0;\n}\n\n.lightning-flash {\n  position: absolute;\n  width: 2px;\n  background: white;\n  opacity: 0.7;\n  transform: translate(-50%, -50%);\n  animation-name: flash-blink;\n  animation-timing-function: ease-in-out;\n  animation-iteration-count: infinite;\n  border-radius: 1px;\n  filter: blur(0.5px);\n  box-shadow: 0 0 4px rgba(255,255,255,0.6);\n\n  z-index: 0;\n}\n\n@keyframes flash-blink {\n  0%, 100% {\n    opacity: 0.1;\n  }\n  50% {\n    opacity: 0.9;\n  }\n}\n\n.lightning-flash-zigzag {\n  position: absolute;\n  width: 2px;\n  height: 0;\n  background: linear-gradient(to bottom, yellow, white);\n  clip-path: polygon(var(--points));\n  animation: flash-zigzag linear forwards;\n  z-index: 3;\n}\n\n@keyframes flash-zigzag {\n  0% {\n    opacity: 1;\n    transform: scaleY(1);\n  }\n  100% {\n    opacity: 0;\n    transform: scaleY(1.2);\n  }\n}\n\n.lightning-svg {\n  position: absolute;\n  transform: translate(-50%, 0);\n  opacity: 0;\n  filter: drop-shadow(0 0 4px rgba(98, 61, 173, 0.6));\n  animation-name: flash-zigzag-svg;\n  animation-timing-function: ease-in-out;\n  animation-iteration-count: 1;\n  z-index: 3;\n}\n\n@keyframes flash-zigzag-svg {\n  0%, 100% {\n    opacity: 0;\n  }\n  40% {\n    opacity: 1;\n  }\n  60% {\n    opacity: 0.5;\n  }\n}\n`;\n\nexport default summaryStyle;\n","import { css } from 'lit';\n\nconst presentStyle = css`\n.present-grid-container {\n  display: flex;\n  flex-direction: column;\n  gap: 4px;\n}\n\n.present-row {\n  display: flex;\n  justify-content: space-between;\n  gap: 16px;\n}\n\n.present-left,\n.present-right {\n  flex: 1;\n}\n\n.present-left {\n  display: flex;\n  justify-content: flex-start;\n}\n\n.present-right {\n  display: flex;\n  justify-content: flex-end;\n}\n\n.present-value-block {\n  display: flex;\n  align-items: center;\n  gap: 4px;\n}\n\n.present-unit {\n  font-size: 0.9em;\n  opacity: 0.8;\n}\n`;\n\nexport default presentStyle;\n","import { css } from 'lit';\n\nconst ultravioletStyle = css`\n.ultraviolet-grid-container {\n  display: flex;\n  flex-direction: column;\n  gap: 4px;\n}\n\n.ultraviolet-row {\n  display: flex;\n  justify-content: space-between;\n  gap: 16px;\n}\n\n.ultraviolet-left,\n.present-right {\n  flex: 1;\n}\n\n.ultraviolet-left {\n  display: flex;\n  justify-content: flex-start;\n}\n\n.ultraviolet-right {\n  display: flex;\n  justify-content: flex-end;\n}\n\n.ultraviolet-value-block {\n  display: flex;\n  align-items: center;\n  gap: 4px;\n}\n\n.ultraviolet-unit {\n  font-size: 0.9em;\n  opacity: 0.8;\n}\n\n------------------------------------------------------------------\n\n// .ultraviolet-grid-container {\n//   display: flex;\n//   flex-direction: column;\n//   gap: 12px;\n// }\n\n// .ultraviolet-row {\n//   display: flex;\n//   justify-content: space-between;\n//   padding: 4px 0;\n// }\n\n// .ultraviolet-value-block {\n//   display: flex;\n//   align-items: center;\n//   gap: 4px;\n// }\n\n// .ultraviolet-unit {\n//   font-size: 0.9em;\n//   opacity: 0.7;\n// }\n\n.ultraviolet-skin-type-grid {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(48px, 1fr));\n  gap: 8px;\n  margin-top: 8px;\n}\n\n.ultraviolet-skin-type-cell {\n  flex: 1;\n  min-width: 48px;\n  height: 48px;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  border-radius: 6px;\n  font-family: 'Segoe UI', sans-serif;\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n  color: black;\n}\n\n.ultraviolet-skin-type-label {\n  font-weight: bold;\n  font-size: 0.95em;\n  line-height: 1em;\n}\n\n.ultraviolet-exposure-time {\n  font-size: 0.75em;\n  margin-top: 2px;\n  color: #222;\n  opacity: 0.85;\n}\n\n\n\n\n\n\n`;\n\nexport default ultravioletStyle;\n","import { css } from 'lit';\n\nconst pollenStyle = css`\n.pollen-grid-container {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(48px, 1fr));\n  gap: 8px 12px;\n  width: 100%;\n  justify-items: center;\n  align-items: end;\n  padding: 8px 4px;\n  box-sizing: border-box;\n}\n\n\n.pollen-stack {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  gap: 4px;\n  min-width: 48px;\n}\n\n\n  .levels {\n    display: flex;\n    flex-direction: column-reverse;\n    gap: clamp(1px, 0.2vw, 2px);\n  }\n\n  .level {\n    width: clamp(16px, 3.5vw, 24px);\n    height: clamp(5px, 0.7vw, 8px);     /* 👈 anche in altezza */\n    border-radius: 3px;\n    opacity: 0.3;\n    transition: opacity 0.2s ease;\n  }\n\n  .level.active {\n    opacity: 1;\n    outline: 1px solid #333;\n  }\n\n  .molto-alto {\n    background-color: #f44336;\n  }\n\n  .alto {\n    background-color: #ff9800;\n  }\n\n  .moderato {\n    background-color: #ffeb3b;\n  }\n\n  .basso {\n    background-color: #4caf50;\n  }\n\n  .pollen-name {\n    font-size: clamp(0.55em, 1.3vw, 0.85em); /* 👈 stringe di più */\n    // font-weight: 500;\n    text-align: center;\n    // color: #333;\n    white-space: nowrap;\n  }\n\n  .label {\n    width: 100%;\n    text-align: center;\n    font-size: clamp(0.55em, 1.3vw, 0.85em);\n    // font-weight: 500;\n    margin-top: clamp(4px, 0.5vw, 8px);\n  }\n`;\n\nexport default pollenStyle;\n","import { css } from 'lit';\n\nconst cameraStyle = css`\n  .camera-container {\n    margin-top: 10px;\n    width: 100%;\n    display: flex;\n    align-items: stretch;\n  }\n\n  .camera-image {\n    aspect-ratio: 16 / 9;\n    width: 100%;\n    position: relative;\n    overflow: hidden;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n  }\n\n  .camera-image > img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nexport default cameraStyle;\n","import { css } from 'lit';\n\nconst weatherForecastStyle = css`\n\n.weather-forecast-grid-container {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(78px, 1fr));\n  column-gap: 2px; /* spazio orizzontale tra i giorni */\n  row-gap: 6px;    /* spazio verticale tra righe, se ci sono */\n  align-items: stretch;\n  font-family: 'Segoe UI', sans-serif;\n  width: 100%;\n}\n  \n.weather-forecast-grid-wrapper {\n  display: flex;\n  flex-direction: column;\n  align-items: center; /* centrare il titolo orizzontalmente */\n}\n\n.weather-forecast-title {\n  font-size: clamp(0.85em, 1vw, 0.95em);\n  font-weight: bold;\n  // margin-bottom: 0.5em;\n  text-align: center;\n}\n\n.weather-forecast-slot {\n  text-align: center;\n  padding: 8px 4px;\n  min-width: 0;\n  overflow: hidden;\n}\n\n.weather-forecast-slot:last-child {\n  border-right: none;\n}\n\n.weather-forecast-label-slot {\n  font-size: 0.9em;\n  font-weight: bold;\n  margin-bottom: 6px; /* ridotto */\n}\n\n.weather-forecast-icon {\n  font-size: 1.6rem; /* ridotto */\n  /* margin: 6px 0; ridotto */\n  height: 32px;\n}\n\n.weather-forecast-temperature {\n  font-size: clamp(0.8em, 1vw, 0.9em); /* leggermente più piccolo */\n  margin: 4px 0; /* meno margine */\n}\n\n.weather-forecast-temperature .high {\n  font-weight: bold;\n}\n\n.weather-forecast-precipitation {\n  font-size: clamp(0.65em, 1vw, 0.75em);\n  line-height: 1.2; /* compatta verticalmente */\n}\n\n.weather-forecast-precipitation .mm {\n  font-weight: bold;\n}\n`;\n\nexport default weatherForecastStyle;\n","import { css } from 'lit';\n\nconst meteodcpalarmStyle = css`\n.meteodcpalarm-grid-container {\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: center;\n  gap: 16px;\n  padding: 12px;\n}\n\n.meteodcpalarm-group {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  flex: 1 1 72px;     /* 👈 cresce, ma non scende sotto i 72px */\n  max-width: 220px;   /* 👈 opzionale: previene allargamento eccessivo */\n  text-align: center;\n}\n\n.meteodcpalarm-group ha-icon {\n  --mdc-icon-size: 36px;\n}\n\n.meteodcpalarm-label {\n  margin-top: 6px;\n  font-size: 0.85em;\n  color: var(--primary-text-color);\n}\n\n\n`;\n\nexport default meteodcpalarmStyle;\n","import { css } from 'lit';\n// import { HomeAssistant } from 'custom-card-helpers/dist';\n\nimport { cwcMoonPhaseIcons } from '../../backup/ha-cwc-consts';\n\nimport cardStyle from '../css/css-base-card';\nimport summaryStyles from '../css/css-summary';\nimport presentStyle from '../css/css-present';\nimport ultravioletStyle from '../css/css-ultraviolet';\nimport pollenStyle from '../css/css-pollen';\nimport cameraStyle from '../css/css-camera';\nimport { iIconsConfig } from '../base/lovelace-base';\nimport weatherForecastStyle from '../css/css-weather-forecast';\nimport meteodcpalarmStyle from '../css/css-meteoalarm';\n\nexport const getMoonIcon = (phase: string): string => cwcMoonPhaseIcons[phase.toLowerCase()];\n\nexport const getWeatherIcon = (\n  condition: string,\n  iconsConfig: iIconsConfig,\n  sunState: string,\n): string => {\n  const isNight = sunState === 'below_horizon';\n  const iconMap = isNight ? iconsConfig.iconsNight : iconsConfig.iconsDay;\n  const iconName = iconMap[condition];\n\n  if (!iconsConfig.path) {\n    console.info('Image path not found.');\n  }\n\n  if (!iconName) {\n    console.info(\n      `Icons issue. Model=${iconsConfig.icons_model}, Time=${isNight ? 'night' : 'day'}, Condition=${condition}`,\n    );\n    return '';\n  }\n\n  return `${iconsConfig.path}/${iconsConfig.iconType}/${iconName}.svg`;\n};\n\n// export const getSensorUnit = (hass: HomeAssistant, measure: string): string => {\n//   const lengthUnit = hass.config.unit_system.length;\n\n//   const unitOverrides: Record<string, string> = {\n//     air_pressure: lengthUnit === 'km' ? 'hPa' : 'inHg',\n//     precipitation: lengthUnit === 'km' ? 'mm' : 'in',\n//     length: lengthUnit,\n//   };\n\n//   if (measure in unitOverrides) {\n//     return unitOverrides[measure];\n//   }\n\n//   const unit = (hass.config.unit_system as Record<string, string>)[measure];\n\n//   if (unit !== undefined) {\n//     return unit;\n//   }\n\n//   console.warn(`Unit for '${measure}' not found in hass.config.unit_system.`);\n//   return '';\n// };\n\nexport const getCardStyles = () => css`\n${cardStyle}\n${summaryStyles}\n${presentStyle}\n${weatherForecastStyle}\n${ultravioletStyle}\n${pollenStyle}\n${cameraStyle}\n${meteodcpalarmStyle}\n`;\n","/* eslint-disable no-underscore-dangle */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n  css,\n  CSSResultGroup,\n  html,\n  LitElement,\n  PropertyValues,\n  TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { HomeAssistant } from 'custom-card-helpers';\n\nimport { defaultColorCss, defaultDarkColorCss } from '../utils/colors';\nimport { iCardConfig, iLovelaceCardConfig } from '../utils/config-schema';\nimport {\n  cwcLocale,\n  hacsImagePath,\n  logo,\n  manImagePath,\n  optConsoleParam1,\n  optConsoleParam2,\n  optConsoleParam3,\n} from '../utils/const';\nimport {\n  getIconModelData,\n  imageExist,\n  loadJSON,\n  logInfo,\n} from '../utils/helper';\nimport { cwcClimacellDayIcons, cwcClimacellNightIcons } from '../iconmodels/im-climacell';\nimport { getCardStyles } from '../utils/helper-render';\nimport { cwcDaytimePirateWeatherIcons, cwcNightlyPirateWeaterIcons } from '../iconmodels/im-pirateweather';\n\nexport interface iTerms {\n   windDirections: string;\n   words: Record<string, string>;\n}\n\nexport interface iIconsConfig {\n  path: string ;\n  iconType: string ;\n  icons_model: string ;\n  iconsDay: { [key: string]: string; } ;\n  iconsNight: { [key: string]: string; } ;\n}\n\nexport interface iLovelaceCard extends HTMLElement {\n  hass?: HomeAssistant;\n  isPanel?: boolean;\n  editMode?: boolean;\n  getCardSize(): number | Promise<number>;\n  setConfig(config: iLovelaceCardConfig): void;\n}\n\nexport function computeDarkMode(hass?: HomeAssistant): boolean {\n  if (!hass) return false;\n  return (hass.themes as any).darkMode as boolean;\n}\n\n/* -------------------- VARIABILI GLOBALI -------------------- */\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n// let loadedTranslations: any[] = [];\n// let resolvedImagePath: string | null = null;\n\nexport async function preloadResources(): Promise<{ translations: any[]; imagePath: string | null }> {\n  const [hacsResult, manResult] = await Promise.all([\n    imageExist(`${hacsImagePath}/static/cloudy.svg`),\n    imageExist(`${manImagePath}/static/cloudy.svg`),\n  ]);\n\n  let imagePath: string | null = null;\n\n  if (hacsResult) {\n    imagePath = hacsImagePath;\n  } else if (manResult) {\n    imagePath = manImagePath;\n  } else {\n    imagePath = null;\n  }\n\n  if (!imagePath) {\n    logInfo(`${logo} - Impossibile determinare il path immagini.`);\n    return { translations: [], imagePath: null };\n  }\n\n  const langs = ['en', 'it', 'nl', 'es', 'de', 'fr', 'sr-latn', 'pt', 'da', 'no-NO', 'cs'];\n  const translPath = `${imagePath}/../transl/`;\n  const translations = await Promise.all(langs.map((lang) => loadJSON(`${translPath}${lang}.json`)));\n\n  return { translations, imagePath };\n}\n\nexport abstract class LovelaceBaseElement extends LitElement {\n  @property({ attribute: false }) public hass!: HomeAssistant;\n\n  @property({ attribute: false }) protected _config?: iCardConfig;\n\n  public isPanel?: boolean = false;\n\n  public editMode?: boolean = false;\n\n  public invalidConfig: boolean = false;\n\n  protected _iconsConfig: iIconsConfig;\n\n  protected _imagesPath: string;\n\n  protected _name: string;\n\n  protected _language: string;\n\n  protected _translations: string[];\n\n  protected _terms: iTerms;\n\n  protected _hasPresent: boolean = false;\n\n  protected _hasDailyForecasts: boolean = false;\n\n  protected _hasHourlyForecasts: boolean = false;\n\n  protected _hasMarineDailyForecasts: boolean = false;\n\n  protected _hasMarineHourlyForecasts: boolean = false;\n\n  protected _hasMetealarm: boolean = false;\n\n  protected _hasDPCalarm: boolean = false;\n\n  protected _hasMeteogram: boolean = false;\n\n  protected _hasAirQuality: boolean = false;\n\n  protected _hasPollen: boolean = false;\n\n  protected _hasUltraviolet: boolean = false;\n\n  protected _hasAlert: boolean = false;\n\n  protected _hasSea: boolean = false;\n\n  protected _hasCamera: boolean = false;\n\n  protected updated(changedProps: PropertyValues): void {\n    super.updated(changedProps);\n    if (changedProps.has('hass') && this.hass) {\n      const currentDarkMode = computeDarkMode(changedProps.get('hass'));\n      const newDarkMode = computeDarkMode(this.hass);\n      if (currentDarkMode !== newDarkMode) {\n        this.toggleAttribute('dark-mode', newDarkMode);\n      }\n    }\n  }\n\n  static get styles(): CSSResultGroup {\n    return [\n      // animations,\n      css`\n        :host {\n          ${defaultColorCss}\n        }\n        :host([dark-mode]) {\n          ${defaultDarkColorCss}\n        }\n        ${getCardStyles()}\n      `,\n    ];\n  }\n\n  public async setConfig(config: iCardConfig) {\n    if (!config) {\n      this.invalidConfig = true;\n      throw new Error('Invalid configuration');\n    }\n\n    // console.log({ card_config: config });\n\n    if (!this._translations?.length || !this._imagesPath) {\n      const { translations, imagePath } = await preloadResources();\n      this._translations = translations;\n      this._imagesPath = imagePath;\n    }\n\n    this._name = config?.weather?.name ?? undefined;\n    this._language = config.language?.toLowerCase() || 'en';\n\n    this._loadTranslations(this._language);\n    // this._initNumberFormatters(this._language);\n\n    // this._setupDisplaySections(config.display ?? []);\n    this._detectDataSections(config);\n\n    this._setupIcons(config.weather?.icons_model);\n    this._config = config;\n\n    logInfo(`${logo} - Config loaded.`);\n  }\n\n  // eslint-disable-next-line class-methods-use-this\n  public getCardSize(): number | Promise<number> {\n    return 1;\n  }\n\n  private _loadTranslations(lang: string) {\n    try {\n      const transls = JSON.parse(this._translations[cwcLocale[lang]]);\n      this._terms = {\n        windDirections: transls.cwcLocWindDirections,\n        words: transls.cwcTerms,\n      };\n\n      logInfo(\n        `${logo}%c card \"${this._name}\", locale is '${lang}'.`,\n        optConsoleParam1,\n        optConsoleParam2,\n        optConsoleParam3,\n      );\n    } catch (e) {\n      const fallback = 'en';\n      const transls = JSON.parse(this._translations[cwcLocale[fallback]]);\n      this._terms = {\n        windDirections: transls.cwcLocWindDirections,\n        words: transls.cwcTerms,\n      };\n\n      logInfo(\n        `${logo}%c card \"${this._name}\" unable to use '${lang}' locale, set as default '${fallback}'.`,\n        optConsoleParam1,\n        optConsoleParam2,\n        optConsoleParam3,\n      );\n    }\n  }\n\n  private _detectDataSections(config: iCardConfig) {\n    this._hasPresent = !!config.weather?.present;\n    this._hasDailyForecasts = !!config.weather?.daily_forecasts;\n    this._hasHourlyForecasts = !!config.weather?.hourly_forecasts;\n    this._hasMarineDailyForecasts = !!config.weather?.marine_daily_forecasts;\n    this._hasMarineHourlyForecasts = !!config.weather?.marine_hourly_forecasts;\n    this._hasMetealarm = !!config.weather?.meteoalarm;\n    this._hasDPCalarm = !!config.weather?.dpcalarm;\n    // this._hasMeteogram = !!config.weather?.forecast?.meteogram;\n    this._hasAirQuality = !!config.airquality;\n    this._hasPollen = config.pollen && Array.isArray(config.pollen.entities) && config.pollen.entities.length > 0;\n    this._hasUltraviolet = !!config.ultraviolet;\n    this._hasCamera = !!config.camera;\n    // this._hasAlert = !!config.alert;\n  }\n\n  private _setupIcons(iconsModel?: string) {\n    this._iconsConfig = {\n      path: this._imagesPath,\n      iconType: this._config?.weather?.animation ? 'animated' : 'static',\n      icons_model: iconsModel || 'pirateweather',\n      iconsDay: cwcDaytimePirateWeatherIcons,\n      iconsNight: cwcNightlyPirateWeaterIcons,\n    };\n\n    if (iconsModel) {\n      const modelData = getIconModelData(iconsModel);\n      this._iconsConfig.icons_model = modelData.iconsModel;\n      this._iconsConfig.iconsDay = modelData.iconsDay;\n      this._iconsConfig.iconsNight = modelData.iconsNight;\n    }\n  }\n\n  /**\n   * generates the card HTML\n   * @return {TemplateResult}\n   */\n  public render(): TemplateResult {\n    if (this.invalidConfig) {\n      return html`\n        <ha-card class=\"ha-card-weather-conditions\">\n            <div class='banner'>\n                <div class=\"header\">ha-card-weather-conditions</div>\n            </div>\n            <div class='content'>\n                Configuration ERROR!\n            </div>\n        </ha-card>\n    `;\n    }\n\n    return this._render();\n  }\n\n  protected abstract _render(): TemplateResult;\n}\n","import { html, nothing } from 'lit';\n\nexport interface WeatherSummaryInterface {\n  title?: string;\n  moonText?: string | undefined;\n  moonIcon?: string;\n  conditionText: string;\n  conditionIcon: string;\n  temperature?: string;\n  temperatureUnit?: string;\n  feelsLikeTerm?: string;\n  temperatureFeelsLike?: string;\n  temperatureFeelsLikeIcon?: string;\n}\n\nconst renderLightningFlashZigzag = (xPercent: number, yPercent: number, segments: number = 7) => {\n  const width = 10; // larghezza in pixel della viewport SVG\n  const height = 20 + Math.random() * 50;\n\n  const points = [];\n  let x = width / 2;\n  let y = 0;\n\n  for (let i = 0; i < segments; i += 1) {\n    // x += (Math.random() * width - width / 2);\n    // y += height / segments;\n    x += (Math.random() * width * 1.5 - width * 0.75); // maggiore zigzag\n    y += (height / segments) * (0.7 + Math.random() * 0.6); // lunghezza variabile\n    points.push(`${x},${y}`);\n  }\n\n  const pathD = `M${width / 2},0 ${points.map((p) => `L${p}`).join(' ')}`;\n\n  const delay = Math.random() * 15.5;\n  const duration = 0.2 + Math.random() * 0.3 * 33;\n\n  return html`\n    <svg\n      class=\"lightning-svg\"\n      style=\"\n        top: ${yPercent}%;\n        left: ${xPercent}%;\n        animation-delay: ${delay}s;\n        animation-duration: ${duration}s;\n      \"\n      width=\"${width}\" height=\"${height}\" viewBox=\"0 0 ${width} ${height}\">\n      <path d=\"${pathD}\" stroke=\"white\" stroke-width=\"1.5\" fill=\"none\" />\n    </svg>\n  `;\n};\n\nconst renderLightningFlashes = (azimuth: number, distance: number, strikes: number) => {\n  const flashes = [];\n  for (let i = 0; i < strikes; i += 1) {\n    const x = Math.random() * 100;\n    const y = Math.random() * 20;\n    flashes.push(renderLightningFlashZigzag(x, y));\n  }\n  return flashes;\n};\n\nconst renderWeatherSummary = ({\n  title,\n  moonText,\n  moonIcon,\n  conditionText,\n  conditionIcon,\n  temperature,\n  temperatureUnit,\n  feelsLikeTerm,\n  temperatureFeelsLike,\n  temperatureFeelsLikeIcon,\n}: WeatherSummaryInterface) => {\n  const lightningAzimuth = 0; // Replace with actual data\n  const lightningDistanceKm = 0; // Replace with actual data\n  const lightningStrikes = 0; // Replace with actual data\n\n  const showLightning =\n  lightningStrikes > 0 &&\n  typeof lightningAzimuth === 'number' &&\n  typeof lightningDistanceKm === 'number';\n\n  if (conditionIcon || moonText || temperature) {\n    return html`\n    <div class=\"summary-wrapper\">\n      ${showLightning ? html`\n        <div class=\"lightning-background\">\n          ${renderLightningFlashes(lightningAzimuth!, lightningDistanceKm!, lightningStrikes)}\n        </div>\n      ` : nothing}\n      <div class=\"summary-grid-container\">\n        ${conditionIcon ? html`\n          <div class=\"summary-col-left\">\n            <img class=\"weather-condition-icon\" src=\"${conditionIcon}\" alt=\"${conditionText}\" />\n          </div>\n        ` : nothing}\n        ${title ? html`\n          <div class=\"summary-top-right\">\n            <span class=\"weather-city-name\">${title}</span>\n          </div>    \n        ` : nothing}\n        ${moonText ? html`\n          <div class=\"summary-bottom-right-left\">\n            <div class=\"moon-row\">\n              <span class=\"summary-moon-icon\">${moonIcon}</span>\n              <span class=\"summary-moon-text\">${moonText}</span>\n            </div>  \n          </div>   \n        ` : nothing}\n        ${temperature ? html`\n          <div class=\"summary-bottom-right-right\">\n            <div class=\"temperature-block\">\n              <div>\n                <span class=\"temperature\">${temperature}</span>\n                <span class=\"temp-unit\">${temperatureUnit}</span>\n              </div>\n              ${temperatureFeelsLike && html`<div class=\"feels-like\">${feelsLikeTerm} <div>${temperatureFeelsLike} ${temperatureUnit}</div></div>`}\n            </div>  \n          </div>\n          ` : nothing}\n      </div>\n    </div>\n    `;\n  }\n\n  return html``;\n};\n\nexport default renderWeatherSummary;\n","import { HomeAssistant } from 'custom-card-helpers/dist';\n\nimport renderWeatherSummary from '../templates/t-summary';\nimport {\n  getEntityNumericValue,\n  getEntityRawValue,\n  getEntityUnit,\n  translate,\n} from '../utils/helper';\n\nimport { getMoonIcon, getWeatherIcon } from '../utils/helper-render';\nimport { iPresentData } from '../utils/config-schema';\nimport { iIconsConfig, iTerms } from '../base/lovelace-base';\n\nconst buildWeatherSummary = (\n  hass: HomeAssistant,\n  language: string,\n  terms: iTerms,\n  iconsConfig: iIconsConfig,\n  name: string,\n  presentData: iPresentData,\n  sunId: string,\n  moonphase: string,\n) => {\n  const moonPhase = getEntityRawValue(hass, moonphase);\n  const moonIcon: string = moonPhase ? getMoonIcon(moonPhase) : '';\n  const sun = getEntityRawValue(hass, sunId);\n  const currentConditions = getEntityRawValue(hass, presentData.condition)?.toLowerCase() || 'na';\n  // eslint-disable-next-line max-len\n  const temperature = presentData.temperature ? getEntityNumericValue({ entityId: presentData.temperature, hass, lang: language }) ?? undefined : undefined;\n  // eslint-disable-next-line max-len\n  const temperatureFeelsLike = presentData.temperature_feelslike ? getEntityNumericValue({ entityId: presentData.temperature_feelslike, hass, lang: language }) ?? undefined : undefined;\n  const temperatureFeelsLikeIcon = hass.states[presentData.temperature_feelslike]?.attributes.icon ?? '';\n\n  return renderWeatherSummary({\n    title: name ?? undefined, // 'Verkhnenovokutlumbetyevo',\n    moonText: (moonphase ? translate(moonPhase, terms.words) : undefined),\n    moonIcon,\n    conditionText: currentConditions,\n    conditionIcon: getWeatherIcon(currentConditions, iconsConfig, sun),\n    temperature,\n    temperatureUnit: getEntityUnit(hass, presentData.temperature),\n    feelsLikeTerm: translate('Feels Like', terms.words),\n    temperatureFeelsLike,\n    temperatureFeelsLikeIcon,\n  });\n};\n\nexport default buildWeatherSummary;\n","import { html } from 'lit';\nimport { getLocale, parseLocalizedNumber } from '../utils/helper';\n\nexport interface iRenderDataItem {\n  value?: number | string | Date;\n  unit?: string;\n  icon?: string;\n  icon_color?: string;\n}\n\nexport interface WeatherData {\n  temperatureHigh?: iRenderDataItem;\n  temperatureLow?: iRenderDataItem;\n  precipitationProbability?: iRenderDataItem;\n  precipitationIntensity?: iRenderDataItem;\n  nextRising?: iRenderDataItem;\n  nextSetting?: iRenderDataItem;\n\n  // precipitation?: iRenderDataItem;\n  humidity?: iRenderDataItem;\n  windBearing?: iRenderDataItem;\n  windSpeed?: iRenderDataItem;\n  pressure?: iRenderDataItem;\n  visibility?: iRenderDataItem;\n}\n\nexport interface iAirQualityData {\n  pm25: iRenderDataItem,\n  pm10:iRenderDataItem,\n  o3: iRenderDataItem,\n  no2: iRenderDataItem,\n  co: iRenderDataItem,\n  so2: iRenderDataItem,\n  epa_aqi: iRenderDataItem,\n  epa_primary_pollutant: iRenderDataItem,\n}\n\nconst isValidInput = (val: unknown): val is string | number => typeof val === 'string' || typeof val === 'number';\n\nconst prepareWeatherPresent = (data: WeatherData, language: string) => {\n  const allItems: iRenderDataItem[] = [];\n\n  const addIfValid = (key: keyof WeatherData, item?: iRenderDataItem) => {\n    if (item?.value === undefined) return;\n\n    allItems.push(item);\n  };\n\n  const pi = data.precipitationIntensity?.value;\n  const pp = data.precipitationProbability?.value;\n\n  if (isValidInput(pi) && isValidInput(pp)) {\n    const locale = getLocale(language);\n    const parsedPI = parseLocalizedNumber(pi, locale);\n    const parsedPP = parseLocalizedNumber(pp, locale);\n\n    if (!Number.isNaN(Number(parsedPI)) && !Number.isNaN(Number(parsedPP)) && parsedPI > 0 && parsedPP > 0) {\n      allItems.push({\n        icon:\n          data.precipitationIntensity.icon ||\n          data.precipitationProbability.icon ||\n          'mdi:weather-rainy',\n        // eslint-disable-next-line max-len\n        value: `${data.precipitationIntensity.value} ${data.precipitationIntensity.unit} / ${data.precipitationProbability.value} ${data.precipitationProbability.unit}`,\n      });\n    }\n  }\n\n  // Temperatura min/max combinata\n  if (\n    data.temperatureLow?.value !== undefined &&\n    data.temperatureHigh?.value !== undefined\n  ) {\n    allItems.push({\n      icon: data.temperatureLow.icon || data.temperatureHigh.icon || 'mdi:thermometer',\n      value: `${data.temperatureLow.value} / ${data.temperatureHigh.value}`,\n      unit: data.temperatureLow.unit || data.temperatureHigh.unit,\n    });\n  }\n\n  const keys: (keyof WeatherData)[] = [\n    'humidity',\n    'pressure',\n    'visibility',\n  ];\n  keys.forEach((k) => addIfValid(k, data[k]));\n\n  // Wind (bearing + speed)\n  // eslint-disable-next-line max-len\n  if (data.windSpeed?.value !== undefined || data.windBearing?.value !== undefined) {\n    allItems.push({\n      icon: data.windSpeed?.icon || 'mdi:weather-windy',\n      value: `${data.windBearing?.value ? `${data.windBearing.value} ` : ''}${data.windSpeed?.value ?? ''}`,\n      unit: data.windSpeed?.unit ? `${data.windSpeed.unit}` : '',\n    });\n  }\n\n  // Sun times\n  ['nextRising', 'nextSetting'].forEach((k) => {\n    const item = data[k as keyof WeatherData];\n    if (item?.value) {\n      allItems.push({\n        icon: item.icon,\n        value: item.value,\n        unit: '',\n      });\n    }\n  });\n\n  return allItems;\n};\n\nconst prepareAirQuality = (data: iAirQualityData, language: string) => {\n  const allItems: iRenderDataItem[] = [];\n\n  const addIfValid = (key: keyof iAirQualityData, item?: iRenderDataItem) => {\n    if (item?.value === undefined) return;\n\n    allItems.push(item);\n  };\n\n  const keys: (keyof iAirQualityData)[] = [\n    'epa_aqi',\n    'epa_primary_pollutant',\n    'pm25',\n    'pm10',\n    'o3',\n    'no2',\n    'co',\n    'so2',\n  ];\n  keys.forEach((k) => addIfValid(k, data[k]));\n\n  return allItems;\n};\n\nexport const renderWeatherPresent = (data, language: string) => {\n  const allItems: iRenderDataItem[] = [];\n\n  const buildBlockLeft = (item: iRenderDataItem) => html`\n    <span class=\"present-value-block\">\n      <ha-icon icon=\"${item.icon}\" style=${item.icon_color ? `color: ${item.icon_color}` : ''}></ha-icon>\n      ${item.value}${item.unit ? html`<span class=\"present-unit\">${item.unit}</span>` : ''}\n    </span>\n  `;\n\n  const buildBlockRight = (item: iRenderDataItem) => html`\n    <span class=\"present-value-block\">\n      ${item.value}${item.unit ? html`<span class=\"present-unit\">${item.unit}</span>` : ''}\n      <ha-icon icon=\"${item.icon}\" style=${item.icon_color ? `color: ${item.icon_color}` : ''}></ha-icon>\n    </span>\n  `;\n\n  allItems.push(...prepareWeatherPresent(data, language), ...prepareAirQuality(data, language));\n\n  const rows = [];\n  for (let i = 0; i < allItems.length; i += 2) {\n    const left = allItems[i];\n    const right = allItems[i + 1];\n\n    if ((left && left.value) || (right && right.value)) {\n      rows.push(html`\n        <div class=\"present-row\">\n          <div class=\"present-left\">${left ? buildBlockLeft(left) : html``}</div>\n          <div class=\"present-right\">${right ? buildBlockRight(right) : html``}</div>\n        </div>\n      `);\n    }\n  }\n\n  return rows.length > 0 ? html`\n    <div class=\"present-grid-container\">\n      ${rows}\n    </div>\n  ` : html``;\n};\n","/* eslint-disable camelcase */\nimport { HomeAssistant } from 'custom-card-helpers/dist';\nimport {\n  getEntityNumericValue,\n  getEntityRawValue,\n  getEntityUnit,\n  getLocaleInfo,\n  getWindDirections,\n} from '../utils/helper';\n// import { getSensorUnit } from '../utils/helper-render';\nimport { renderWeatherPresent } from '../templates/t-present';\nimport { iPresentData } from '../utils/config-schema';\nimport { iTerms } from '../base/lovelace-base';\n\nconst present = (hass: HomeAssistant, language: string, cwcLocWindDirections, presentData: iPresentData, sunId: string) => {\n  const localeInfo = getLocaleInfo(language);\n  const sunEntity = sunId ? hass.states[sunId] : undefined;\n  const { next_rising, next_setting } = sunEntity?.attributes ?? {};\n\n  const next_rising_formatted = next_rising ? new Date(next_rising).toLocaleTimeString(localeInfo.locale, {\n    hour: '2-digit',\n    minute: '2-digit',\n    second: '2-digit',\n    hour12: false,\n    timeZone: localeInfo.timezone,\n  }) : undefined;\n\n  const next_setting_formatted = next_rising ? new Date(next_setting).toLocaleTimeString(localeInfo.locale, {\n    hour: '2-digit',\n    minute: '2-digit',\n    second: '2-digit',\n    hour12: false,\n    timeZone: localeInfo.timezone,\n  }) : undefined;\n\n  return {\n    nextRising: { value: next_rising_formatted, icon: 'mdi:weather-sunset-up' },\n    nextSetting: { value: next_setting_formatted, icon: 'mdi:weather-sunset-down' },\n\n    precipitationIntensity: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.precipitation_intensity, hass, lang: language, decimals: 2 }),\n      unit: getEntityUnit(hass, presentData.precipitation_intensity),\n      icon: 'mdi:weather-rainy',\n    },\n    precipitationProbability: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.precipitation_probability, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.precipitation_probability),\n      icon: 'mdi:weather-rainy',\n    },\n    humidity: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.humidity, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.humidity),\n      icon: 'mdi:water-percent',\n    },\n    windBearing: { value: getWindDirections(getEntityRawValue(hass, presentData.wind_bearing), cwcLocWindDirections) },\n    windSpeed: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.wind_speed, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.wind_speed),\n      icon: 'mdi:weather-windy',\n    },\n    pressure: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.pressure, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.pressure),\n      icon: 'mdi:gauge',\n    },\n    visibility: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.visibility, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.visibility),\n      icon: 'mdi:weather-fog',\n    },\n    temperatureHigh: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.temperature_max, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.temperature_max),\n      icon: 'mdi:thermometer',\n    },\n    temperatureLow: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.temperature_min, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.temperature_min),\n      icon: 'mdi:thermometer',\n    },\n  };\n};\n\n// const presentFromForecastData = (hass: HomeAssistant, language: string, forecastCfg: Forecast) => {\n//   const getValue = (obj: Record<string, string>) => {\n//     const [key, entityId] = Object.entries(obj)[0] ?? [];\n//     const state = entityId && hass.states[entityId]?.state;\n//     return state !== undefined ? formatNumber({ stringNumber: state, lang: language, fractionDigits: 0 }) : undefined;\n//   };\n\n//   const {\n//     temperature_high = {},\n//     temperature_low = {},\n//     precipitation_probability = {},\n//     precipitation_intensity = {},\n//   } = forecastCfg;\n\n//   return {\n//     temperatureHigh: { value: getValue(temperature_high), unit: getEntityUnit(hass, temperature_high), icon: 'mdi:thermometer' },\n//     temperatureLow: { value: getValue(temperature_low), unit: getEntityUnit(hass, 'temperature'), icon: 'mdi:thermometer' },\n//     precipitationProbability: { value: getValue(precipitation_probability), unit: '%', icon: 'mdi:weather-rainy' },\n//     precipitationIntensity: { value: getValue(precipitation_intensity), unit: getEntityUnit(hass, 'precipitation'), icon: 'mdi:weather-rainy' },\n//   };\n// };\n\nconst buildWeatherPresent = (\n  hass: HomeAssistant,\n  language: string,\n  terms: iTerms,\n  presentData: iPresentData,\n  sunId: string,\n) => {\n  const lang = language || hass.selectedLanguage || hass.language;\n\n  const presentObj = present(hass, lang, terms.windDirections, presentData, sunId);\n  // const presentFromForecastObj = presentFromForecastData(hass, language, forecastCfg);\n\n  // console.debug('buildWeatherPresent', { presentObj });\n  return renderWeatherPresent({ ...presentObj }, lang);\n};\n\nexport default buildWeatherPresent;\n","import { html } from 'lit';\n\nexport interface RenderDataItem {\n  value?: number | string | Date;\n  unit?: string;\n  icon?: string;\n}\nexport interface RenderData {\n  protectionWindow?: RenderDataItem,\n  currentUVLevel?: RenderDataItem,\n  currentUVIndex?: RenderDataItem,\n  maxUVIndex?: RenderDataItem,\n  currentOzoneLevel?: RenderDataItem,\n}\n\nexport interface RenderSkinData {\n  skinType1: RenderDataItem,\n  skinType2: RenderDataItem,\n  skinType3: RenderDataItem,\n  skinType4: RenderDataItem,\n  skinType5: RenderDataItem,\n  skinType6: RenderDataItem,\n}\n\nconst num = ['I', 'II', 'III', 'IV', 'V', 'VI'];\nconst colors = ['#F1D1B1', '#E4B590', '#CF9F7D', '#B67851', '#A15E2D', '#513938'];\n\nconst getTextColor = (hex: string): string => {\n  const c = hex.replace('#', '');\n  const r = parseInt(c.substr(0, 2), 16);\n  const g = parseInt(c.substr(2, 2), 16);\n  const b = parseInt(c.substr(4, 2), 16);\n  const brightness = (r * 299 + g * 587 + b * 114) / 1000;\n  return brightness > 125 ? '#000' : '#fff';\n};\n\nconst renderUltraviolet = (data: RenderData, skinData: RenderSkinData) => {\n  const allItems: RenderDataItem[] = [];\n\n  const buildBlockLeft = (item: RenderDataItem) => html`\n    <span class=\"ultraviolet-value-block\">\n      <ha-icon icon=\"${item.icon}\" style=\"${item.value === 'on' ? 'color: red;' : ''}\"></ha-icon>\n      ${item.value}${item.unit ? html`<span class=\"ultraviolet-unit\">${item.unit}</span>` : ''}\n    </span>\n  `;\n\n  const buildBlockRight = (item: RenderDataItem) => html`\n    <span class=\"ultraviolet-value-block\">\n      ${item.value}${item.unit ? html`<span class=\"ultraviolet-unit\">${item.unit}</span>` : ''}\n      <ha-icon icon=\"${item.icon}\" style=\"${item.value === 'on' ? 'color: red;' : ''}\"></ha-icon>\n    </span>\n  `;\n  \n  const addIfValid = (key: keyof RenderData, item?: RenderDataItem) => {\n    if (item?.value === undefined) return;\n\n    allItems.push(item);\n  };\n\n  let keys: (keyof RenderData)[] = [\n    'protectionWindow',\n    'currentUVLevel',\n  ];\n  keys.forEach((k) => addIfValid(k, data[k]));\n\n  // UV Level current/max combinata\n  if (\n    data.currentUVIndex?.value !== undefined &&\n    data.maxUVIndex?.value !== undefined\n  ) {\n    allItems.push({\n      icon: data.currentUVIndex.icon || data.maxUVIndex.icon || 'mdi:weather-sunny',\n      value: `${data.currentUVIndex.value} / ${data.maxUVIndex.value}`,\n      unit: data.currentUVIndex.unit || data.maxUVIndex.unit,\n    });\n  }\n\n  keys = [\n    'currentOzoneLevel',\n  ];\n  keys.forEach((k) => addIfValid(k, data[k]));\n\n  const summaryRows = [];\n  for (let i = 0; i < allItems.length; i += 2) {\n    const left = allItems[i];\n    const right = allItems[i + 1];\n    summaryRows.push(html`\n      <div class=\"ultraviolet-row\">\n        <div class=\"ultraviolet-left\">${left ? buildBlockLeft(left) : html``}</div>\n        <div class=\"ultraviolet-right\">${right ? buildBlockRight(right) : html``}</div>\n      </div>\n    `);\n  }\n\n  const skinTypes = [\n    skinData.skinType1,\n    skinData.skinType2,\n    skinData.skinType3,\n    skinData.skinType4,\n    skinData.skinType5,\n    skinData.skinType6,\n  ];\n\n  const renderSkinGrid = html`\n  <div class=\"ultraviolet-skin-type-grid\">\n  ${skinTypes.map((item, i) => {\n    const bgColor = colors[i];\n    const textColor = getTextColor(bgColor);\n    return html`\n      <div\n        class=\"ultraviolet-skin-type-cell\"\n        style=\"background: ${bgColor};\"\n        title=\"Fototipo ${num[i]}\"\n      >\n        <div class=\"ultraviolet-skin-type-label\">${num[i]}</div>\n        <div class=\"ultraviolet-exposure-time\" style=\"color: ${textColor};\">${item.value || '--'}</div>\n      </div>\n    `;\n  })}\n  </div>\n  `;\n\n  return html`\n    <div class=\"ultraviolet-grid-container\">\n      ${summaryRows}\n      ${renderSkinGrid}\n    </div>\n  `;\n};\n\nexport default renderUltraviolet;\n","import { HomeAssistant } from 'custom-card-helpers/dist';\n\nimport { getEntityNumericValue, getEntityRawValue, pad } from '../utils/helper';\nimport renderUltraviolet from '../templates/t-ultraviolet';\nimport { iUltraviolet } from '../utils/config-schema';\n\n// const getRawValue = (hass: HomeAssistant, entityId?: string): string | undefined => entityId && hass.states[entityId]?.state;\n// const getValue = (hass: HomeAssistant, entityId?: string, lang: string = 'en', decimals = 0): string | undefined => {\n//   const state = entityId && hass.states[entityId]?.state;\n//   return state !== undefined ? formatNumber(state, lang, decimals) : undefined;\n// };\n\nconst getTime = (state?: string | number): string => {\n  const value = typeof state === 'string' && state.toLowerCase() === 'unknown'\n    ? NaN\n    : Number(state);\n  // console.debug(state);\n  if (!Number.isFinite(value) || value < 0) return '--';\n\n  const hours = Math.floor(value / 60);\n  const minutes = value % 60;\n\n  return hours > 0\n    ? `${hours}:${pad(minutes, 2)} h`\n    : `${minutes} m`;\n};\n\nconst summaryData = (hass: HomeAssistant, lang: string, uv: iUltraviolet) => ({\n  protectionWindow: {\n    value: (!getEntityRawValue(hass, uv.protection_window) || getEntityRawValue(hass, uv.protection_window) === 'unknown' ? 'off' :\n      getEntityRawValue(hass, uv.protection_window)\n    ),\n    icon: 'mdi:sunglasses',\n  },\n  currentUVLevel: { value: getEntityRawValue(hass, uv.uv_level), icon: 'mdi:weather-sunny' },\n  currentUVIndex: { value: getEntityNumericValue({ entityId: uv.uv_index, hass, lang }), unit: 'UV Idx', icon: 'mdi:weather-sunny' },\n  maxUVIndex: { value: getEntityNumericValue({ entityId: uv.max_uv_index, hass, lang }), unit: 'UV Idx', icon: 'mdi:weather-sunny' },\n  currentOzoneLevel: { value: getEntityNumericValue({ entityId: uv.ozone_level, hass, lang }), unit: 'DU', icon: 'mdi:vector-triangle' },\n});\n\nconst skinData = (hass: HomeAssistant, lang: string, uv: iUltraviolet) => ({\n  skinType1: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_1, hass, lang })) },\n  skinType2: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_2, hass, lang })) },\n  skinType3: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_3, hass, lang })) },\n  skinType4: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_4, hass, lang })) },\n  skinType5: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_5, hass, lang })) },\n  skinType6: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_6, hass, lang })) },\n});\n\nconst buildUltraviolet = (hass: HomeAssistant, lang: string, uv: iUltraviolet) =>\n  // eslint-disable-next-line implicit-arrow-linebreak\n  renderUltraviolet({ ...summaryData(hass, lang, uv) }, { ...skinData(hass, lang, uv) });\n\nexport default buildUltraviolet;\n","import { html } from 'lit';\n\nexport interface iPollenData {\n  name: string;\n  value: number;\n}\n\nconst LEVEL_NAMES = ['basso', 'moderato', 'alto', 'molto-alto', 'estremo'];\n\nconst getLevelIndex = (value: number, levelMin: number, levelMax: number): number => {\n  const range = levelMax - levelMin + 1;\n  const step = range / LEVEL_NAMES.length;\n  const index = Math.floor((value - levelMin) / step);\n  return Math.min(index, LEVEL_NAMES.length - 1);\n};\n\nexport const renderPollen = (data: iPollenData[], levelMin: number, levelMax: number) => {\n  const numLevels = levelMax - levelMin + 1;\n  const levels = LEVEL_NAMES.slice(0, numLevels);\n\n  if (data.length === 0) {\n    return html``;\n  }\n\n  return html`\n    <div class=\"pollen-grid-container\">\n      ${data.map((item) => {\n    const activeIndex = getLevelIndex(item.value, levelMin, levelMax);\n    return html`\n          <div class=\"pollen-stack\">\n            <div class=\"levels\">\n              ${levels.map((levelName, index) => html`\n                <div\n                  class=\"level ${levelName} ${index === activeIndex ? 'active' : ''}\"\n                  title=\"${levelName}\"\n                ></div>\n              `)}\n            </div>\n            <div class=\"pollen-name\">${item.name}</div>\n          </div>\n        `;\n  })}\n    </div>\n  `;\n};\n","import { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iPollen } from '../utils/config-schema';\nimport { getEntityRawValue, string2Number } from '../utils/helper';\nimport { iPollenData, renderPollen } from '../templates/t-pollen';\n\nconst buildPollen = (hass: HomeAssistant, lang: string, pollen: iPollen) => {\n  const allItems: iPollenData[] = [];\n  if (Array.isArray(pollen.entities) && pollen.entities.length > 0) {\n    pollen.entities.forEach((item) => {\n      const rawvalue = getEntityRawValue(hass, item.entity);\n      if (rawvalue && rawvalue !== 'unknown' && rawvalue !== 'unavailable') {\n        let value: number = string2Number(getEntityRawValue(hass, item.entity));\n\n        if (Number.isNaN(value) || value < pollen.min || value > pollen.max) {\n          value = 0;\n        }\n\n        allItems.push({\n          name: item.name,\n          value,\n        });\n      }\n      // console.log(`Nome: ${item.name}, Entità: ${item.entity}`);\n    });\n  }\n\n  return renderPollen(allItems, pollen.min, pollen.max);\n};\n\nexport default buildPollen;\n","/* eslint-disable max-len */\n/* eslint-disable camelcase */\nimport { html } from 'lit';\n\nexport interface iForecastDataItem {\n  value?: number | string | Date;\n  unit?: string;\n  img?: string;\n  icon?: string;\n  iconColor?: string;\n}\n\nexport const renderWeatherForecast = (forecastType: number, data: Record<string, iForecastDataItem>[]) => {\n  const rows = data.map((dayData) => {\n    const day = dayData.reference?.value;\n    const img = dayData.condition?.img;\n    const icon = dayData.condition?.icon;\n    const iconColor = dayData.condition?.iconColor;\n    const tempLow = dayData.temperature_low?.value;\n    const tempHigh = dayData.temperature_high?.value;\n    const tempHLUnit = dayData.temperature_high?.unit || dayData.temperature_low?.unit;\n    const precipProb: number = Number(dayData.precipitation_probability?.value ?? 0);\n    const precipInt = dayData.precipitation_intensity?.value;\n    const precipUnit = dayData.precipitation_intensity?.unit;\n\n    const temp = dayData.temperature?.value;\n    const tempUnit = dayData.temperature?.unit || dayData.temperature_feelslike?.unit;\n    const temp_feelslike = dayData.temperature_feelslike?.value;\n    const wind_speed = dayData.wind_speed?.value;\n    const wind_speedUnit = dayData.wind_speed?.unit;\n    const wind_bearing = dayData.wind_bearing?.value;\n\n    const wind_wave_height_max = dayData.wind_wave_height_max?.value;\n    const swell_wave_height_max = dayData.swell_wave_height_max?.value;\n    const wave_height_max = dayData.wave_height_max?.value;\n    const wave_direction = dayData.wave_direction?.value;\n    const wave_direction_degrees = dayData.wave_direction?.icon;\n    const wave_height_max_unit = dayData.wave_height_max?.unit;\n\n    return html`\n      <div class=\"weather-forecast-slot\">\n        ${day ? html`<div class=\"weather-forecast-label-slot\">${day}</div>` : ''}\n        ${img ? html`<img class=\"weather-forecast-icon\" src=\"${img}\" alt=\"${img}\" />` : ''}\n        ${icon ? html`<ha-icon icon=\"${icon}\" style=${iconColor ? `color: ${iconColor}` : ''}></ha-icon>` : ''}\n        ${\n  tempLow !== undefined && tempHigh !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${tempLow} / <span class=\"high\">${tempHigh}${tempHLUnit ? ` ${tempHLUnit}` : ''}</span>\n                </div>\n              `\n    : ''\n}\n        ${\n  temp !== undefined && temp_feelslike !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${temp} / <span class=\"high\">${temp_feelslike}${tempUnit ? ` ${tempUnit}` : ''}</span>\n                </div>\n              `\n    : ''\n}\n        ${\n  wind_speed !== undefined && wind_bearing !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${wind_speed} ${wind_speedUnit} ${wind_bearing}</span>\n                </div>\n              `\n    : ''\n}\n        ${\n  wave_height_max !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${wave_height_max} ${wave_height_max_unit ? ` ${wave_height_max_unit}` : ''}\n                </div>\n              `\n    : ''\n}\n        ${\n  wave_direction !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${wave_direction_degrees ? html`<ha-icon\n                        icon=\"mdi:arrow-up-thin\"\n                        style=\"display:inline-block; transform: rotate(${wave_direction_degrees}deg);\"\n                      ></ha-icon>` : ''} ${wave_direction}\n                </div>\n              `\n    : ''\n}\n        ${\n  wind_wave_height_max !== undefined && swell_wave_height_max !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${swell_wave_height_max} / ${wind_wave_height_max} ${wave_height_max_unit ? ` ${wave_height_max_unit}` : ''}\n                </div>\n              `\n    : ''\n}\n        ${\n  precipProb !== undefined && precipInt !== undefined && precipProb !== 0\n    ? html`\n                <div class=\"weather-forecast-precipitation\">\n                  ${precipProb} % / <span class=\"mm\">${precipInt}${precipUnit ? ` ${precipUnit}` : ''}</span>\n                </div>\n              `\n    : ''\n}\n      </div>\n    `;\n  });\n\n  let title = 'Daily';\n  if (forecastType === 1) {\n    title = 'Hourly';\n  } else if (forecastType === 2) {\n    title = 'Marine daily';\n  } else if (forecastType === 3) {\n    title = 'Marine hourly';\n  }\n\n  return html`\n  <div class=\"weather-forecast-grid-wrapper\">\n    <div class=\"weather-forecast-title\">${title} forecast</div>\n    <div class=\"weather-forecast-grid-container\">\n      ${rows}\n    </div>\n  </div>\n  `;\n};\n","import { HomeAssistant } from 'custom-card-helpers/dist';\nimport { getWeatherIcon } from '../utils/helper-render';\nimport { iIconsConfig, iTerms } from '../base/lovelace-base';\nimport {\n  getEntityIcon,\n  getEntityNumericValue,\n  getEntityRawAttribute,\n  getEntityRawValue,\n  getEntityUnit,\n  getLocaleInfo,\n  getWindDirections,\n} from '../utils/helper';\nimport { iconPrecipitation, iconTemperature } from '../utils/const';\nimport { iForecastDataItem, renderWeatherForecast } from '../templates/t-weather-forecast';\nimport {\n  iDailyForecast,\n  iHourlyForecast,\n  iMarineDailyForecast,\n  iMarineHourlyForecast,\n} from '../utils/config-schema';\n\nconst getDefaultIcon = (metric: string): string => {\n  if (metric.includes('temperature')) return iconTemperature;\n  if (metric.includes('precipitation')) return iconPrecipitation;\n  return 'mdi:help-circle-outline';\n};\n\nconst buildHourlyForecastSlot = (\n  hass: HomeAssistant,\n  lang: string,\n  cwcLocWindDirections,\n  forecast: iHourlyForecast,\n  forecastType: number,\n  iconsConfig: iIconsConfig,\n  sunState: string,\n  slotId: string,\n) => {\n  const record: Record<string, iForecastDataItem> = {};\n  const localeInfo = getLocaleInfo(lang);\n\n  let datetime: Date;\n\n  // Condizione meteo\n  if (forecast.condition && forecast.condition[slotId]) {\n    record['condition'] = {\n      img: getWeatherIcon(getEntityRawValue(hass, forecast.condition[slotId]), iconsConfig, sunState),\n    };\n  }\n\n  // Wind Bearing\n  if (forecast.wind_bearing && forecast.wind_bearing[slotId]) {\n    record['wind_bearing'] = {\n      value: getWindDirections(getEntityRawValue(hass, forecast.wind_bearing[slotId]), cwcLocWindDirections),\n    };\n  }\n   \n  // Metriche da gestire\n  const metrics = [\n    'temperature',\n    'temperature_feelslike',\n    'precipitation_intensity',\n    'precipitation_probability',\n    'wind_speed',\n  ];\n\n  metrics.forEach((metricKey) => {\n    const metricSlots = forecast[metricKey];\n    const entityId = metricSlots?.[slotId];\n    let decimals = 0;\n\n    if (!entityId) return;\n\n    if (metricKey === 'precipitation_intensity') decimals = 2;\n\n    datetime = new Date(getEntityRawAttribute(hass, entityId, 'datetime'));\n\n    record[metricKey] = {\n      value: getEntityNumericValue({\n        entityId, hass, lang, decimals,\n      }),\n      unit: getEntityUnit(hass, entityId),\n      img: getEntityIcon(hass, entityId) || getDefaultIcon(metricKey),\n    };\n  });\n\n  if (datetime && Object.keys(record).length > 0) {\n    const hourTime = datetime.toLocaleTimeString(localeInfo.locale, {\n      hour: '2-digit',\n      minute: '2-digit',\n      timeZone: localeInfo.timezone,\n    });\n\n    record['reference'] = {\n      value: (forecastType === 0 ? hourTime : hourTime),\n    };\n  }\n\n  return record;\n};\n\nconst buildDailyForecastSlot = (\n  hass: HomeAssistant,\n  lang: string,\n  forecast: iDailyForecast,\n  forecastType: number,\n  iconsConfig: iIconsConfig,\n  sunState: string,\n  slotId: string,\n) => {\n  const record: Record<string, iForecastDataItem> = {};\n  const localeInfo = getLocaleInfo(lang);\n\n  let datetime: Date;\n\n  // Gestione condizione meteo\n  if (forecast.condition && forecast.condition[slotId]) {\n    record['condition'] = {\n      img: getWeatherIcon(getEntityRawValue(hass, forecast.condition[slotId]), iconsConfig, sunState),\n    };\n  }\n\n  // Lista fissa delle metriche da considerare\n  const metrics = [\n    'temperature_high',\n    'temperature_low',\n    'precipitation_intensity',\n    'precipitation_probability',\n  ];\n\n  metrics.forEach((metricKey) => {\n    const metricSlots = forecast[metricKey];\n    const entityId = metricSlots?.[slotId];\n    let decimals = 0;\n\n    if (!entityId) return;\n\n    if (metricKey === 'precipitation_intensity') {\n      decimals = 2;\n    }\n\n    datetime = new Date(getEntityRawAttribute(hass, entityId, 'datetime'));\n    // console.debug(`>>> ${entityId} ${lang} ${getEntityNumericValue({ entityId, hass, lang })}`);\n    record[metricKey] = {\n      value: getEntityNumericValue({\n        entityId, hass, lang, decimals,\n      }),\n      unit: getEntityUnit(hass, entityId),\n      img: getEntityIcon(hass, entityId) || getDefaultIcon(metricKey),\n    };\n  });\n\n  if (datetime && Object.keys(record).length > 0) {\n    // Giorno della settimana abbreviato (es. \"Lun\")\n    const weekday = datetime.toLocaleDateString(localeInfo.locale, {\n      weekday: 'short',\n      timeZone: 'UTC', // forza la lettura senza conversione locale\n    });\n\n    // Ora e minuti (es. \"13:45\")\n    const hourday = datetime.toLocaleTimeString(localeInfo.locale, {\n      hour: '2-digit',\n      minute: '2-digit',\n      timeZone: localeInfo.timezone,\n    });\n\n    record['reference'] = {\n      value: (forecastType === 0 ? weekday.toUpperCase() : hourday),\n    };\n  }\n\n  return record;\n};\n\nconst buildMarineDailyForecastSlot = (\n  hass: HomeAssistant,\n  lang: string,\n  cwcLocWindDirections,\n  forecast: iMarineDailyForecast,\n  forecastType: number,\n  iconsConfig: iIconsConfig,\n  sunState: string,\n  slotId: string,\n) => {\n  const record: Record<string, iForecastDataItem> = {};\n\n  const fieldColor = (\n    waveHeightMax: number,\n    swellWaveHeightMax: number,\n    windWaveHeightMax: number,\n  ) => {\n    // 🟥 Bandiera rossa – condizioni pericolose\n    if (waveHeightMax >= 1.8) {\n      return 'red';\n    }\n\n    if (swellWaveHeightMax >= 1.5 && windWaveHeightMax >= 0.8) {\n      return 'red';\n    }\n\n    // 🟨 Bandiera gialla – condizioni da attenzionare\n    if (waveHeightMax >= 1.0) {\n      return 'yellow';\n    }\n\n    if (swellWaveHeightMax >= 0.8) {\n      return 'yellow';\n    }\n\n    if (windWaveHeightMax >= 0.6) {\n      return 'yellow';\n    }\n\n    // 🟩 Bandiera verde – condizioni sicure\n    return 'green';\n  };\n\n  const localeInfo = getLocaleInfo(lang);\n\n  let datetime: Date;\n\n  // Gestione condizione meteo\n  if (\n    forecast.wave_height_max &&\n    forecast.swell_wave_height_max &&\n    forecast.wind_wave_height_max &&\n    forecast.swell_wave_height_max[slotId] &&\n    forecast.wind_wave_height_max[slotId]\n  ) {\n    record['condition'] = {\n      icon: 'mdi:flag-variant',\n      iconColor: fieldColor(forecast.wave_height_max[slotId], forecast.swell_wave_height_max[slotId], forecast.wind_wave_height_max[slotId]),\n    };\n  }\n\n  // Wind Bearing\n  if (forecast.wave_direction && forecast.wave_direction[slotId]) {\n    record['wave_direction'] = {\n      value: getWindDirections(getEntityRawValue(hass, forecast.wave_direction[slotId]), cwcLocWindDirections),\n      icon: getEntityRawValue(hass, forecast.wave_direction[slotId]),\n    };\n  }\n\n  // Lista fissa delle metriche da considerare\n  const metrics = [\n    'wave_height_max',\n    'swell_wave_height_max',\n    'wind_wave_height_max',\n  ];\n\n  metrics.forEach((metricKey) => {\n    const metricSlots = forecast[metricKey];\n    const entityId = metricSlots?.[slotId];\n    const decimals = 1;\n\n    if (!entityId) return;\n\n    datetime = new Date(getEntityRawAttribute(hass, entityId, 'datetime'));\n    // console.debug(`>>> ${entityId} ${lang} ${getEntityNumericValue({ entityId, hass, lang })}`);\n    record[metricKey] = {\n      value: getEntityNumericValue({\n        entityId, hass, lang, decimals,\n      }),\n      unit: getEntityUnit(hass, entityId),\n      img: getEntityIcon(hass, entityId) || getDefaultIcon(metricKey),\n    };\n  });\n\n  if (datetime && Object.keys(record).length > 0) {\n    // Giorno della settimana abbreviato (es. \"Lun\")\n    const weekday = datetime.toLocaleDateString(localeInfo.locale, {\n      weekday: 'short',\n      timeZone: 'UTC', // forza la lettura senza conversione locale\n    });\n\n    // Ora e minuti (es. \"13:45\")\n    const hourday = datetime.toLocaleTimeString(localeInfo.locale, {\n      hour: '2-digit',\n      minute: '2-digit',\n      timeZone: localeInfo.timezone,\n    });\n\n    record['reference'] = {\n      value: (forecastType === 2 ? weekday.toUpperCase() : hourday),\n    };\n  }\n\n  return record;\n};\n\nconst buildWeatherForecast = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  dailyForecast: iDailyForecast,\n  hourlyForecast: iHourlyForecast,\n  marineDailyForecasts: iMarineDailyForecast,\n  marineHourlyForecasts: iMarineHourlyForecast,\n  forecastType: (0 | 1 | 2 | 3),\n  iconsConfig: iIconsConfig,\n  sunEntityId: string,\n) => {\n  const voidRecord: Record<string, iForecastDataItem>[] = [];\n  \n  const sunState = getEntityRawValue(hass, sunEntityId);\n\n  let dailyForecastData = voidRecord;\n  if (dailyForecast) {\n    const dailySlotIds = Object.keys(\n      dailyForecast.condition ||\n      dailyForecast.temperature_high || dailyForecast.temperature_low ||\n      dailyForecast.precipitation_intensity || dailyForecast.precipitation_probability ||\n      {},\n    );\n    dailyForecastData = dailySlotIds.map((slotId) => buildDailyForecastSlot(\n      hass,\n      lang,\n      dailyForecast,\n      forecastType,\n      iconsConfig,\n      sunState,\n      slotId,\n    ));\n  }\n\n  let hourlyforecastData = voidRecord;\n  if (hourlyForecast) {\n    const hourlySlotIds = Object.keys(\n      hourlyForecast.condition ||\n      hourlyForecast.temperature || hourlyForecast.temperature_feelslike ||\n      hourlyForecast.precipitation_intensity || hourlyForecast.precipitation_probability ||\n      {},\n    );\n    hourlyforecastData = hourlySlotIds.map((slotId) => buildHourlyForecastSlot(\n      hass,\n      lang,\n      terms.windDirections,\n      hourlyForecast,\n      forecastType,\n      iconsConfig,\n      sunState,\n      slotId,\n    ));\n  }\n\n  let marineDailyForecastData = voidRecord;\n  if (marineDailyForecasts) {\n    const marineDailySlotIds = Object.keys(\n      marineDailyForecasts.swell_wave_height_max ||\n      marineDailyForecasts.wave_direction || marineDailyForecasts.wave_height_max ||\n      marineDailyForecasts.wind_wave_height_max ||\n      {},\n    );\n    marineDailyForecastData = marineDailySlotIds.map((slotId) => buildMarineDailyForecastSlot(\n      hass,\n      lang,\n      terms.windDirections,\n      marineDailyForecasts,\n      forecastType,\n      iconsConfig,\n      sunState,\n      slotId,\n    ));\n  }\n\n  switch (forecastType) {\n    case 0:\n      return renderWeatherForecast(forecastType, dailyForecastData);\n    case 1:\n      return renderWeatherForecast(forecastType, hourlyforecastData);\n    case 2:\n      return renderWeatherForecast(forecastType, marineDailyForecastData);\n    default:\n      return renderWeatherForecast(forecastType, voidRecord);\n  }\n};\n\nexport default buildWeatherForecast;\n","import { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iTerms } from '../base/lovelace-base';\nimport renderCamera from '../templates/t-camera';\n\nconst buildCamera = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  handlePopup: (e: Event, entityId: string) => void,\n  cameraId: string,\n) => {\n  const camera = cameraId && hass.states[cameraId];\n\n  const entityPicture = camera?.attributes?.entity_picture;\n  const friendlyName = camera?.attributes?.friendly_name ?? cameraId;\n\n  return renderCamera(handlePopup, cameraId, entityPicture, friendlyName);\n};\n\nexport default buildCamera;\n","import { html } from 'lit';\n\nconst renderCamera = (\n  handlePopup: (e: Event, entityId: string) => void,\n  cameraId: string,\n  cameraPicture: string,\n  friendlyName: string,\n) => {\n  if (!cameraPicture) return html``;\n\n  return html`\n    <div \n      class=\"camera-container\"\n      @click=${(e: Event) => handlePopup(e, cameraId)}\n    >\n      <div class=\"camera-image\">\n        <img \n          src=\"${cameraPicture}\" \n          alt=\"${friendlyName}\"\n          loading=\"lazy\"\n        />\n      </div>\n    </div>\n  `;\n};\n\nexport default renderCamera;\n","/* eslint-disable camelcase */\n/* eslint-disable no-else-return */\n/* eslint-disable object-curly-newline */\nimport { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iAirQuality } from '../utils/config-schema';\nimport { getEntityNumericValue, getEntityRawValue, getEntityUnit } from '../utils/helper';\nimport { renderWeatherPresent } from '../templates/t-present';\n\n/**\n * Restituisce un colore (in formato hex) in base al valore dell'indice EPA AQI.\n * @param {number} aqi - Valore AQI compreso tra 0 e 500\n * @returns {string} - Colore esadecimale associato alla fascia AQI\n */\nfunction getAQIColor(aqi: number): string {\n  if (aqi <= 50) {\n    return '#009966'; // Verde (Buona)\n  } else if (aqi <= 100) {\n    return '#ffde33'; // Giallo (Moderata)\n  } else if (aqi <= 150) {\n    return '#ff9933'; // Arancione (Sensibili)\n  } else if (aqi <= 200) {\n    return '#cc0033'; // Rosso (Non salutare)\n  } else if (aqi <= 300) {\n    return '#660099'; // Viola (Molto non salutare)\n  } else {\n    return '#7e0023'; // Marrone scuro (Pericolosa)\n  }\n}\n\nconst buildAirQuality = (\n  hass: HomeAssistant,\n  language: string,\n  airquality: iAirQuality,\n) => {\n  const lang = language || hass.selectedLanguage || hass.language;\n\n  const pm25 = getEntityNumericValue({ entityId: airquality.pm25, hass, lang: language, decimals: 0 });\n  const pm10 = getEntityNumericValue({ entityId: airquality.pm10, hass, lang: language, decimals: 0 });\n  const o3 = getEntityNumericValue({ entityId: airquality.o3, hass, lang: language, decimals: 1 });\n  const no2 = getEntityNumericValue({ entityId: airquality.no2, hass, lang: language, decimals: 0 });\n  const co = getEntityNumericValue({ entityId: airquality.co, hass, lang: language, decimals: 1 });\n  const so2 = getEntityNumericValue({ entityId: airquality.so2, hass, lang: language, decimals: 0 });\n  const epa_aqi = getEntityNumericValue({ entityId: airquality.epa_aqi, hass, lang: language, decimals: 0 });\n  const epa_primary_pollutant = getEntityRawValue(hass, airquality.epa_primary_pollutant);\n\n  const airQualityData = {\n    pm25: {\n      value: (pm25 ? `pm2.5 ${pm25}` : pm25),\n      unit: getEntityUnit(hass, airquality.pm25) || 'µg/m³',\n      icon: 'mdi:weather-hazy',\n    },\n    pm10: {\n      value: (pm10 ? `pm10 ${pm10}` : pm10),\n      unit: getEntityUnit(hass, airquality.pm10) || 'µg/m³',\n      icon: 'mdi:weather-hazy',\n    },\n    o3: {\n      value: (o3 ? `o3 ${o3}` : o3),\n      unit: getEntityUnit(hass, airquality.o3) || 'µg/m³',\n      icon: 'mdi:molecule',\n    },\n    no2: {\n      value: (no2 ? `no2 ${no2}` : no2),\n      unit: getEntityUnit(hass, airquality.no2) || 'µg/m³',\n      icon: 'mdi:molecule',\n    },\n    co: {\n      value: (co ? `co ${co}` : co),\n      unit: getEntityUnit(hass, airquality.co) || 'µg/m³',\n      icon: 'mdi:molecule',\n    },\n    so2: {\n      value: (so2 ? `so2 ${so2}` : so2),\n      unit: getEntityUnit(hass, airquality.so2) || 'µg/m³',\n      icon: 'mdi:molecule',\n    },\n    epa_aqi: {\n      value: (epa_aqi ? `Air Quality Index ${epa_aqi}` : epa_aqi),\n      // unit: getEntityUnit(hass, airquality.epa_aqi) || 'µg/m³',\n      icon: 'mdi:weather-hazy',\n      icon_color: getAQIColor(Number(getEntityRawValue(hass, airquality.epa_aqi))),\n    },\n    epa_primary_pollutant: {\n      value: (epa_primary_pollutant ? `Primary ${epa_primary_pollutant}` : epa_primary_pollutant),\n      // unit: getEntityUnit(hass, airquality.epa_aqi) || 'µg/m³',\n      icon: 'mdi:weather-hazy',\n    },\n  };\n\n  return renderWeatherPresent(airQualityData, lang);\n};\n\nexport default buildAirQuality;\n","/* eslint-disable camelcase */\n/* eslint-disable quote-props */\nimport { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iTerms } from '../base/lovelace-base';\nimport { iDPCAlert } from '../utils/config-schema';\nimport renderMeteoDPCalarm, { iWeatherMeteoDPCAlarmDataInterface } from '../templates/t-meteoalarm';\nimport { getLocaleInfo } from '../utils/helper';\n\nconst getEffectiveLabel = (effective: string) => {\n  const effectiveDatetime = new Date(effective);\n  const now = new Date();\n\n  // Reset dell'ora per confronto solo a livello di giorno\n  const today = new Date(now.getFullYear(), now.getMonth(), now.getDate());\n  const effectiveDate = new Date(effectiveDatetime.getFullYear(), effectiveDatetime.getMonth(), effectiveDatetime.getDate());\n\n  const msInDay = 24 * 60 * 60 * 1000;\n  const dayDifference = Math.round((effectiveDate.getTime() - today.getTime()) / msInDay);\n\n  let effectiveLabel: 'oggi' | 'domani' | 'dopodomani' | undefined;\n\n  if (dayDifference === 0) {\n    effectiveLabel = 'oggi';\n  } else if (dayDifference === 1) {\n    effectiveLabel = 'domani';\n  } else if (dayDifference === 2) {\n    effectiveLabel = 'dopodomani';\n  } else {\n    effectiveLabel = undefined;\n  }\n  return effectiveLabel;\n};\n\nconst buildMeteoAlarmData = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  meteoalarmId: string,\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n): Record<string, iWeatherMeteoDPCAlarmDataInterface> => {\n  const eventIcon: Record<string, string> = {\n    'wind': 'mdi:weather-windy',\n    'snow-ice': 'mdi:snowflake-alert',\n    'thunderstorm': 'mdi:weather-lightning',\n    'fog': 'mdi:weather-fog',\n    'high-temperature': 'mdi:weather-sunny-alert',\n    'low-temperature': 'mdi:thermometer-low',\n    'coastal-event': 'mdi:home-flood',\n    'forest-fire': 'mdi:pine-tree-fire',\n    'avalanche': 'mdi:image-filter-hdr',\n    'rain': 'mdi:weather-pouring',\n    'flood': 'mdi:home-flood',\n    'rain-flood': 'mdi:weather-pouring',\n    'marine-hazard': 'mdi:weather-hurricane',\n    'drought': 'mdi:water-off',\n  };\n\n  const eventIconColor: Record<string, string> = {\n    green: 'green',\n    yellow: '#ffa600',\n    orange: 'orange',\n    red: 'red',\n  };\n\n  const meteoalarm = meteoalarmId && hass.states[meteoalarmId];\n  if (!meteoalarm?.attributes) return {};\n\n  const fpcData: Record<string, iWeatherMeteoDPCAlarmDataInterface> = {};\n\n  if (meteoalarm.state === 'on' && meteoalarm.attributes) {\n    const localeInfo = getLocaleInfo(lang);\n    const {\n      event,\n      severity,\n      awareness_type,\n      awareness_level,\n      effective,\n    } = meteoalarm.attributes;\n\n    const awarenessType = awareness_type?.split(';')[1]?.trim().toLowerCase() || '';\n    const awarenessLevel = awareness_level?.split(';')[1]?.trim().toLowerCase() || '';\n    const eventName = event || '';\n    const severityLevel = severity?.split(';')[1]?.trim() || '';\n    const effectiveDatetime = getEffectiveLabel(effective);\n\n    fpcData['meteoalarm'] = {\n      event: eventName,\n      severity: severityLevel,\n      icon: eventIcon[awarenessType] || 'mdi:alert',\n      icon_color: eventIconColor[awarenessLevel] || 'grey',\n      datetime: (new Date(effective)).toLocaleDateString(localeInfo.locale, {\n        weekday: 'short',\n        timeZone: localeInfo.timezone,\n      }).toLocaleUpperCase(),\n    };\n  }\n\n  return fpcData;\n};\n\nconst buildDPCAlarmData = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  dpcalarm: iDPCAlert,\n) => {\n  if (!dpcalarm) return {};\n\n  const localeInfo = getLocaleInfo(lang);\n  const eventIconColor = {\n    0: 'gray',\n    1: 'green',\n    2: '#ffa600',\n    3: 'orange',\n    4: 'red',\n  };\n\n  const sources = ['thunderstorms', 'hydraulic', 'hydrogeological'];\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const fpcData: Record<string, iWeatherMeteoDPCAlarmDataInterface> = {};\n\n  sources.forEach((key) => {\n    const entityId = dpcalarm[key as keyof iDPCAlert];\n    const entity = entityId && hass.states[entityId];\n\n    if (entity && entity.state === 'on' && entity.attributes) {\n      const { level, info, icon } = entity.attributes;\n      fpcData[key] = {\n        event: info,\n        severity: level,\n        icon,\n        icon_color: eventIconColor[level],\n        datetime: (new Date()).toLocaleDateString(localeInfo.locale, {\n          weekday: 'short',\n          timeZone: localeInfo.timezone,\n        }).toLocaleUpperCase(),\n      };\n    }\n  });\n  return fpcData;\n};\n\nconst buildMeteoDPCalarm = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  meteoalarmId: string,\n  dpcalarm: iDPCAlert, \n) => {\n  const alarmsData = { ...buildMeteoAlarmData(hass, lang, terms, meteoalarmId), ...buildDPCAlarmData(hass, lang, terms, dpcalarm) };\n  // console.debug('buildMeteoDPCalarm', alarmsData);\n  return renderMeteoDPCalarm(alarmsData);\n};\n\nexport default buildMeteoDPCalarm;\n","import { html } from 'lit';\n\nexport interface iWeatherMeteoDPCAlarmDataInterface {\n  event?: string,\n  severity?: string,\n  icon?: string,\n  icon_color?: string,\n  datetime?: string,\n}\n\nconst renderMeteoDPCalarm = (\n  meteoDPCalarmData: Record<string, iWeatherMeteoDPCAlarmDataInterface> | null,\n) => {\n  if (!meteoDPCalarmData || Object.keys(meteoDPCalarmData).length === 0) return html``;\n\n  return html`\n  <div class=\"meteodcpalarm-grid-container\">\n    ${Object.entries(meteoDPCalarmData).map(([key, data]) => html`\n      <div class=\"meteodcpalarm-group\">\n        <ha-icon icon=\"${data.icon}\" style=\"color: ${data.icon_color};\"></ha-icon>\n        <div class=\"meteodcpalarm-label\">${data.datetime}</div>\n        <div class=\"meteodcpalarm-label\">${data.event}</div>\n      </div>\n    `)}\n  </div>\n  `;\n};\n\nexport default renderMeteoDPCalarm;\n","/* eslint-disable no-underscore-dangle */\nimport { html, TemplateResult } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { LovelaceBaseElement, preloadResources } from './base/lovelace-base';\n\nimport buildWeatherSummary from './builder/b-summary';\nimport buildWeatherPresent from './builder/b-present';\nimport buildUltraviolet from './builder/b-ultraviolet';\nimport buildPollen from './builder/b-pollen';\nimport buildWeatherForecast from './builder/b-weather-forecast';\nimport buildCamera from './builder/b-camera';\nimport buildAirQuality from './builder/b-airquality';\nimport buildMeteoDPCalarm from './builder/b-meteoalarm';\n\nconst { translations, imagePath } = await preloadResources(); // esecuzione immediata\n\n/* -------------------- DEFINIZIONE COMPONENTE -------------------- */\n\n@customElement('ha-card-weather-conditions')\n// eslint-disable-next-line import/prefer-default-export\nexport class HaCardWeatherConditions extends LovelaceBaseElement {\n  _translations = translations;\n\n  _imagesPath = imagePath;\n\n  // eslint-disable-next-line class-methods-use-this\n  protected _render(): TemplateResult {\n    return html`\n      <ha-card class=\"ha-card-weather-conditions\">\n        <div class=\"nd-container\">\n          ${this._buildTemplate()}\n        </div>\n      </ha-card>\n    `;\n  }\n\n  private _buildTemplate(): TemplateResult {\n    let summary = html``;\n    let present = html``;\n    let dailyWeatherForecast = html``;\n    let hourlyWeatherForecast = html``;\n    let marineDailyWeatherForecast = html``;\n    let marineHourlyWeatherForecast = html``;\n    let meteoDPCalarm = html``;\n    let ultraviolet = html``;\n    let pollen = html``;\n    let airQuality = html``;\n    let camera = html``;\n\n    const getWeatherForecast = (mode: 0 | 1 | 2 | 3) => buildWeatherForecast(\n      this.hass,\n      this._language,\n      this._terms,\n      this._config.weather.daily_forecasts,\n      this._config.weather.hourly_forecasts,\n      this._config.weather.marine_daily_forecasts,\n      this._config.weather.marine_hourly_forecasts,\n      mode,\n      this._iconsConfig,\n      this._config.weather.sun,\n    );\n\n    if (this._hasPresent) {\n      summary = buildWeatherSummary(\n        this.hass,\n        this._language,\n        this._terms,\n        this._iconsConfig,\n        this._config.weather?.name,\n        this._config?.weather?.present || null,\n        this._config?.weather?.sun,\n        this._config?.weather?.moonphase,\n      );\n    }\n\n    if (this._hasPresent) {\n      present = buildWeatherPresent(\n        this.hass,\n        this._language,\n        this._terms,\n        this._config?.weather?.present || {},\n        this._config?.weather?.sun,\n      );\n    }\n\n    if (this._hasMetealarm || this._hasDPCalarm) {\n      meteoDPCalarm = buildMeteoDPCalarm(\n        this.hass,\n        this._language,\n        this._terms,\n        this._config?.weather?.meteoalarm,\n        this._config?.weather?.dpcalarm,\n      );\n    }\n\n    if (this._hasDailyForecasts) {\n      dailyWeatherForecast = getWeatherForecast(0);\n    }\n    if (this._hasHourlyForecasts) {\n      hourlyWeatherForecast = getWeatherForecast(1);\n    }\n    if (this._hasMarineDailyForecasts) {\n      marineDailyWeatherForecast = getWeatherForecast(2);\n    }\n    if (this._hasMarineHourlyForecasts) {\n      marineHourlyWeatherForecast = getWeatherForecast(3);\n    }\n\n    if (this._hasUltraviolet) {\n      ultraviolet = buildUltraviolet(this.hass, this._language, this._config.ultraviolet);\n    }\n\n    if (this._hasPollen) {\n      pollen = buildPollen(this.hass, this._language, this._config.pollen);\n    }\n\n    if (this._hasAirQuality) {\n      airQuality = buildAirQuality(this.hass, this._language, this._config.airquality);\n    }\n\n    if (this._hasCamera) {\n      camera = buildCamera(this.hass, this._language, this._terms, this._handlePopup.bind(this), this._config.camera);\n    }\n\n    return html`\n    ${summary}\n    ${present}\n    ${hourlyWeatherForecast}\n    ${dailyWeatherForecast}\n    ${marineHourlyWeatherForecast}\n    ${marineDailyWeatherForecast}\n    ${meteoDPCalarm}\n    ${pollen}\n    ${ultraviolet}\n    ${airQuality}\n    ${camera}`;\n  }\n\n  /**\n   * Apre il popup di dettaglio per l'entità specificata.\n   * @param e L'evento click originale.\n   * @param entityId L'ID dell'entità Home Assistant da mostrare.\n   */\n  protected _handlePopup(e: Event, entityId: string) {\n    e.stopPropagation();\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const moreInfoEvent = new Event('hass-more-info', { composed: true }) as any;\n    moreInfoEvent.detail = { entityId };\n    this.dispatchEvent(moreInfoEvent);\n  }\n}\n"],"names":["__decorate","decorators","target","key","desc","d","c","arguments","length","r","Object","getOwnPropertyDescriptor","Reflect","decorate","i","defineProperty","SuppressedError","t","globalThis","e","ShadowRoot","ShadyCSS","nativeShadow","Document","prototype","CSSStyleSheet","s","Symbol","o","WeakMap","n$3","constructor","this","_$cssResult$","Error","cssText","styleSheet","get","replaceSync","set","toString","reduce","n","cssRules","is","h","getOwnPropertyNames","getOwnPropertySymbols","getPrototypeOf","a","trustedTypes","l","emptyScript","p","reactiveElementPolyfillSupport","u","toAttribute","Boolean","Array","JSON","stringify","fromAttribute","Number","parse","f","b","attribute","type","String","converter","reflect","useDefault","hasChanged","metadata","litPropertyMetadata","y$1","HTMLElement","addInitializer","_$Ei","push","observedAttributes","finalize","_$Eh","keys","createProperty","state","hasOwnProperty","create","wrapped","elementProperties","noAccessor","getPropertyDescriptor","call","requestUpdate","configurable","enumerable","getPropertyOptions","Map","finalized","properties","_$Eu","elementStyles","finalizeStyles","styles","isArray","Set","flat","reverse","unshift","toLowerCase","super","_$Ep","isUpdatePending","hasUpdated","_$Em","_$Ev","_$ES","Promise","enableUpdating","_$AL","_$E_","forEach","addController","_$EO","add","renderRoot","isConnected","hostConnected","removeController","delete","size","createRenderRoot","shadowRoot","attachShadow","shadowRootOptions","adoptedStyleSheets","map","document","createElement","litNonce","setAttribute","textContent","appendChild","connectedCallback","disconnectedCallback","hostDisconnected","attributeChangedCallback","_$AK","_$ET","removeAttribute","_$Ej","hasAttribute","C","_$EP","has","_$Eq","reject","scheduleUpdate","performUpdate","shouldUpdate","willUpdate","hostUpdate","update","_$EM","_$AE","hostUpdated","firstUpdated","updated","updateComplete","getUpdateComplete","y","mode","ReactiveElement","reactiveElementVersions","createPolicy","createHTML","Math","random","toFixed","slice","createComment","v","_","m","RegExp","g","$","x","_$litType$","strings","values","T","for","E","A","createTreeWalker","P","V","lastIndex","exec","test","startsWith","N","parts","el","currentNode","content","firstChild","replaceWith","childNodes","nextNode","nodeType","hasAttributes","getAttributeNames","endsWith","getAttribute","split","index","name","ctor","H","I","L","k","tagName","append","data","indexOf","innerHTML","S","_$Co","_$Cl","_$litDirective$","_$AO","_$AT","_$AS","M","_$AV","_$AN","_$AD","_$AM","parentNode","_$AU","creationScope","importNode","R","nextSibling","z","_$AI","_$Cv","_$AH","_$AA","_$AB","options","startNode","endNode","_$AR","iterator","O","insertBefore","createTextNode","_$AC","_$AP","remove","setConnected","element","fill","j","toggleAttribute","capture","once","passive","removeEventListener","addEventListener","handleEvent","host","litHtmlPolyfillSupport","litHtmlVersions","renderOptions","_$Do","renderBefore","render","_$litPart$","_$litElement$","litElementHydrateSupport","LitElement","litElementPolyfillSupport","litElementVersions","kind","init","defaultColorCss","css","defaultDarkColorCss","logo","hacsImagePath","manImagePath","optConsoleParam1","optConsoleParam2","optConsoleParam3","cwcLocale","en","it","nl","es","de","fr","pt","da","cs","ru","cwcBuienradarDayIcons","snowy","rainy","cloudy","partlycloudy","lightning","clear","cwcBuienradarNightIcons","cwcClimacellDayIcons","freezing_rain_heavy","freezing_rain","freezing_rain_light","freezing_drizzle","ice_pellets_heavy","ice_pellets","ice_pellets_light","snow_heavy","snow","snow_light","flurries","tstorm","rain_heavy","rain_light","rain","drizzle","fog_light","fog","mostly_cloudy","partly_cloudy","mostly_clear","cwcClimacellNightIcons","sunny","cwcDarkskyDayIcons","sleet","wind","cwcDarkskyNightIcons","cwcDefaultHassDayIcons","exceptional","hail","pouring","windy","cwcDefaultHassNightIcons","cwcOpenWeatherMapDayIcons","thunderstorm","mist","cwcOpenWeatherMapNightIcons","cwcDaytimePirateWeatherIcons","cwcNightlyPirateWeaterIcons","iconsModels","pirateweather","iconsDay","iconsNight","climacell","darksky","openweathermap","buienradar","defaulthass","translate","term","dictionary","find","getLocaleInfo","lang","locale","timezone","ja","cwc","getLocale","zh","toUpperCase","formatNumber","stringNumber","fractionDigits","useGrouping","number","parseFloat","isNaN","effectiveFormatter","getFormatter","Intl","NumberFormat","minimumFractionDigits","maximumFractionDigits","format","getEntityRawValue","hass","entityId","states","getEntityRawAttribute","attributes","getEntityNumericValue","decimals","undefined","getEntityUnit","unit_of_measurement","getEntityIcon","icon","getWindDirections","wd","cwcLocWindDirections","wdNumber","console","error","floor","imageExist","imageSrc","timeout","resolve","img","Image","timer","setTimeout","src","onload","clearTimeout","onerror","logInfo","message","info","parseLocalizedNumber","value","normalized","replace","cwcMoonPhaseIcons","new_moon","new","waxing_crescent","first_quarter","waxing_gibbous","full","full_moon","waning_gibbous","third_quarter","last_quarter","waning_crescent","cardStyle","summaryStyle","presentStyle","ultravioletStyle","pollenStyle","cameraStyle","weatherForecastStyle","meteodcpalarmStyle","getWeatherIcon","condition","iconsConfig","sunState","isNight","iconName","path","iconType","icons_model","computeDarkMode","themes","darkMode","async","preloadResources","hacsResult","manResult","all","imagePath","translations","translPath","full_path_file","response","fetch","ok","err","status","statusText","text","loadJSON","LovelaceBaseElement","isPanel","editMode","invalidConfig","_hasPresent","_hasDailyForecasts","_hasHourlyForecasts","_hasMarineDailyForecasts","_hasMarineHourlyForecasts","_hasMetealarm","_hasDPCalarm","_hasMeteogram","_hasAirQuality","_hasPollen","_hasUltraviolet","_hasAlert","_hasSea","_hasCamera","changedProps","currentDarkMode","newDarkMode","summaryStyles","setConfig","config","_translations","_imagesPath","_name","weather","_language","language","_loadTranslations","_detectDataSections","_setupIcons","_config","getCardSize","transls","_terms","windDirections","words","cwcTerms","fallback","present","daily_forecasts","hourly_forecasts","marine_daily_forecasts","marine_hourly_forecasts","meteoalarm","dpcalarm","airquality","pollen","entities","ultraviolet","camera","iconsModel","_iconsConfig","animation","modelData","modelName","warn","getIconModelData","html","_render","property","buildWeatherSummary","terms","presentData","sunId","moonphase","moonPhase","moonIcon","sun","currentConditions","temperature","temperatureFeelsLike","temperature_feelslike","temperatureFeelsLikeIcon","renderWeatherSummary","title","moonText","conditionText","conditionIcon","temperatureUnit","feelsLikeTerm","nothing","isValidInput","val","prepareWeatherPresent","allItems","pi","precipitationIntensity","pp","precipitationProbability","parsedPI","parsedPP","unit","temperatureLow","temperatureHigh","addIfValid","item","windSpeed","windBearing","prepareAirQuality","renderWeatherPresent","buildBlockRight","icon_color","rows","left","right","buildWeatherPresent","selectedLanguage","presentObj","localeInfo","sunEntity","next_rising","next_setting","nextRising","Date","toLocaleTimeString","hour","minute","second","hour12","timeZone","nextSetting","precipitation_intensity","precipitation_probability","humidity","wind_bearing","wind_speed","pressure","visibility","temperature_max","temperature_min","num","colors","renderUltraviolet","skinData","currentUVIndex","maxUVIndex","summaryRows","skinTypes","skinType1","skinType2","skinType3","skinType4","skinType5","skinType6","renderSkinGrid","bgColor","textColor","hex","parseInt","substr","getTextColor","getTime","NaN","isFinite","hours","minutes","width","padStart","pad","summaryData","uv","protectionWindow","protection_window","currentUVLevel","uv_level","uv_index","max_uv_index","currentOzoneLevel","ozone_level","set_skin_type_1","set_skin_type_2","set_skin_type_3","set_skin_type_4","set_skin_type_5","set_skin_type_6","LEVEL_NAMES","renderPollen","levelMin","levelMax","numLevels","levels","activeIndex","getLevelIndex","step","min","levelName","buildPollen","rawvalue","entity","string2Number","input","formatToParts","group","part","decimal","max","renderWeatherForecast","forecastType","dayData","day","reference","iconColor","tempLow","temperature_low","tempHigh","temperature_high","tempHLUnit","precipProb","precipInt","precipUnit","temp","tempUnit","temp_feelslike","wind_speedUnit","wind_wave_height_max","swell_wave_height_max","wave_height_max","wave_direction","wave_direction_degrees","wave_height_max_unit","getDefaultIcon","metric","includes","buildWeatherForecast","dailyForecast","hourlyForecast","marineDailyForecasts","marineHourlyForecasts","sunEntityId","voidRecord","dailyForecastData","slotId","buildDailyForecastSlot","forecast","record","datetime","metricKey","metricSlots","weekday","toLocaleDateString","hourday","hourlyforecastData","buildHourlyForecastSlot","hourTime","marineDailyForecastData","buildMarineDailyForecastSlot","fieldColor","waveHeightMax","swellWaveHeightMax","windWaveHeightMax","buildCamera","handlePopup","cameraId","entityPicture","entity_picture","renderCamera","cameraPicture","friendlyName","friendly_name","buildMeteoAlarmData","meteoalarmId","eventIcon","avalanche","flood","drought","eventIconColor","green","yellow","orange","red","fpcData","event","severity","awareness_type","awareness_level","effective","awarenessType","trim","awarenessLevel","eventName","severityLevel","effectiveDatetime","now","today","getFullYear","getMonth","getDate","effectiveDate","dayDifference","round","effectiveLabel","getEffectiveLabel","toLocaleUpperCase","buildDPCAlarmData","level","buildMeteoDPCalarm","alarmsData","meteoDPCalarmData","entries","HaCardWeatherConditions","_buildTemplate","summary","dailyWeatherForecast","hourlyWeatherForecast","marineDailyWeatherForecast","marineHourlyWeatherForecast","meteoDPCalarm","airQuality","getWeatherForecast","buildUltraviolet","buildAirQuality","pm25","pm10","o3","no2","co","so2","epa_aqi","epa_primary_pollutant","airQualityData","aqi","_handlePopup","bind","stopPropagation","moreInfoEvent","Event","composed","detail","dispatchEvent","customElements","define","customElement"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6]}\n"
  },
  {
    "path": "dist/transl/cs.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"S\",\n    \"NNE\": \"SSV\",\n    \"NE\": \"SV\",\n    \"ENE\": \"VSV\",\n    \"E\": \"V\",\n    \"ESE\": \"VJV\",\n    \"SE\": \"JV\",\n    \"SSE\": \"JJV\",\n    \"S\": \"J\",\n    \"SSW\": \"JJZ\",\n    \"SW\": \"JZ\",\n    \"WSW\": \"ZJZ\",\n    \"W\": \"Z\",\n    \"WNW\": \"ZSZ\",\n    \"NW\": \"SZ\",\n    \"NNW\": \"SSZ\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Pocitová teplota\",\n    \"new_moon\": \"Nov\",\n    \"new\": \"Nov\",\n    \"waxing_crescent\": \"Dorůstající srpek\",\n    \"first_quarter\": \"První čtvrť\",\n    \"waxing_gibbous\": \"Dorůstající měsíc\",\n    \"full\": \"Úplněk\",\n    \"full_moon\": \"Úplněk\",\n    \"waning_gibbous\": \"Couvající měsíc\",\n    \"third_quarter\": \"Třetí čtvrť\",\n    \"last_quarter\": \"Poslední čtvrť\",\n    \"waning_crescent\": \"Ubývající srpek\"\n  }\n}"
  },
  {
    "path": "dist/transl/da.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"N\",\n    \"NNE\": \"NNØ\",\n    \"NE\": \"NØ\",\n    \"ENE\": \"ØNØ\",\n    \"E\": \"Ø\",\n    \"ESE\": \"ØSØ\",\n    \"SE\": \"SØ\",\n    \"SSE\": \"SSØ\",\n    \"S\": \"S\",\n    \"SSW\": \"SSV\",\n    \"SW\": \"SV\",\n    \"WSW\": \"VSV\",\n    \"W\": \"V\",\n    \"WNW\": \"VNV\",\n    \"NW\": \"NV\",\n    \"NNW\": \"NNV\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Føles som\",\n    \"new_moon\": \"Nymåne\",\n    \"new\": \"Nymåne\",\n    \"waxing_crescent\": \"Tiltagende halvmåne\",\n    \"first_quarter\": \"Første kvartal\",\n    \"waxing_gibbous\": \"Tiltagende måne\",\n    \"full\": \"Fuldmåne\",\n    \"full_moon\": \"Fuldmåne\",\n    \"waning_gibbous\": \"Aftagende måne\",\n    \"third_quarter\": \"Tredje kvartal\",\n    \"last_quarter\": \"Sidste kvartal\",\n    \"waning_crescent\": \"Aftagende halvmåne\"\n  }\n}"
  },
  {
    "path": "dist/transl/de.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"N\", \n    \"NNE\": \"NNO\", \n    \"NE\": \"NO\",\n    \"ENE\": \"ONO\", \n    \"E\": \"O\", \n    \"ESE\": \"OSO\", \n    \"SE\": \"SO\",\n    \"SSE\": \"SSO\", \n    \"S\": \"S\", \n    \"SSW\": \"SSW\", \n    \"SW\": \"SW\", \n    \"WSW\": \"WSW\", \n    \"W\": \"W\",\n    \"WNW\": \"WNW\", \n    \"NW\": \"NW\",\n    \"NNW\": \"NNW\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Gefühlt\",\n    \"new_moon\": \"Neumond\",\n    \"new\": \"Neumond\",\n    \"waxing_crescent\": \"Zunehmende Sichel\",\n    \"first_quarter\": \"Erstes Viertel\",\n    \"waxing_gibbous\": \"Zunehmender Halbmond\",\n    \"full\": \"Vollmond\",\n    \"full_moon\": \"Vollmond\",\n    \"waning_gibbous\": \"Abnehmender Halbmond\",\n    \"third_quarter\": \"Drittes Viertel\",\n    \"last_quarter\": \"Letztes Viertel\",\n    \"waning_crescent\": \"Abnehmende Sichel\"\n  }\n}"
  },
  {
    "path": "dist/transl/en.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"N\",\n    \"NNE\": \"NNE\",\n    \"NE\": \"NE\",\n    \"ENE\": \"ENE\",\n    \"E\": \"E\",\n    \"ESE\": \"ESE\",\n    \"SE\": \"SE\",\n    \"SSE\": \"SSE\",\n    \"S\": \"S\",\n    \"SSW\": \"SSW\",\n    \"SW\": \"SW\",\n    \"WSW\": \"WSW\",\n    \"W\": \"W\",\n    \"WNW\": \"WNW\",\n    \"NW\": \"NW\",\n    \"NNW\": \"NNW\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Feels Like\",\n    \"new_moon\": \"New moon\",\n    \"new\": \"New moon\",\n    \"waxing_crescent\": \"Waxing crescent\",\n    \"first_quarter\": \"First quarter\",\n    \"waxing_gibbous\": \"Waxing Gibbous\",\n    \"full\": \"Full\",\n    \"full_moon\": \"Full\",\n    \"waning_gibbous\": \"Waning Gibbous\",\n    \"third_quarter\": \"Third Quarter\",\n    \"last_quarter\": \"Last Quarter\",\n    \"waning_crescent\": \"Waning Crescent\"\n  }\n}"
  },
  {
    "path": "dist/transl/es.json",
    "content": "{\n\"cwcLocWindDirections\": {\n\"N\": \"N\",\n\"NNE\": \"NNE\",\n\"NE\": \"NE\",\n\"ENE\": \"ENE\",\n\"E\": \"E\",\n\"ESE\": \"ESE\",\n\"SE\": \"SE\",\n\"SSE\": \"SSE\",\n\"S\": \"S\",\n\"SSW\": \"SSO\",\n\"SW\": \"SO\",\n\"WSW\": \"OSO\",\n\"W\": \"O\",\n\"WNW\": \"ONO\",\n\"NW\": \"NO\",\n\"NNW\": \"NNO\"\n},\n\n\"cwcTerms\": {\n\"Feels Like\" : \"Sensación térmica\",\n\"new_moon\": \"Luna nueva\",\n\"new\": \"Luna nueva\",\n\"waxing_crescent\": \"Luna creciente\",\n\"first_quarter\": \"Cuarto creciente\",\n\"waxing_gibbous\": \"Luna menguante gibosa\",\n\"full\": \"Luna llena\",\n\"full_moon\": \"Luna llena\",\n\"waning_gibbous\": \"Luna menguante gibosa\",\n\"third_quarter\": \"Media luna\",\n\"last_quarter\": \"Cuarto menguante\",\n\"waning_crescent\": \"Luna menguante\"\n}\n}"
  },
  {
    "path": "dist/transl/fr.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"N\",\n    \"NNE\": \"NNE\",\n    \"NE\": \"NE\",\n    \"ENE\": \"ENE\",\n    \"E\": \"E\",\n    \"ESE\": \"ESE\",\n    \"SE\": \"SE\",\n    \"SSE\": \"SSE\",\n    \"S\": \"S\",\n    \"SSW\": \"SSO\",\n    \"SW\": \"SO\",\n    \"WSW\": \"OSO\",\n    \"W\": \"O\",\n    \"WNW\": \"ONO\",\n    \"NW\": \"NO\",\n    \"NNW\": \"NNO\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Ressentie\", \n    \"new_moon\": \"Nouvelle lune\", \n    \"new\": \"Nouvelle lune\", \n    \"waxing_crescent\": \"Premier croissant\", \n    \"first_quarter\": \"Premier quartier\",\n    \"waxing_gibbous\": \"Gibbeuse croissante\",\n    \"full\": \"Pleine lune\",\n    \"full_moon\": \"Pleine lune\",\n    \"waning_gibbous\": \"Gibbeuse décroissante\",\n    \"third_quarter\": \"Dernier quartier\",\n    \"last_quarter\": \"Dernier quartier\",\n    \"waning_crescent\": \"Lune décroissante\"\n  }\n}"
  },
  {
    "path": "dist/transl/it.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"N\", \n    \"NNE\": \"NNE\",\n    \"NE\": \"NE\", \n    \"ENE\": \"ENE\", \n    \"E\": \"E\",\n    \"ESE\": \"ESE\", \n    \"SE\": \"SE\", \n    \"SSE\": \"SSE\",\n    \"S\": \"S\", \n    \"SSW\": \"SSO\", \n    \"SW\": \"SO\", \n    \"WSW\": \"OSO\", \n    \"W\": \"O\", \n    \"WNW\": \"ONO\", \n    \"NW\": \"NO\", \n    \"NNW\": \"NNO\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Percepita\", \n    \"new_moon\": \"Novilunio\", \n    \"new\": \"Novilunio\", \n    \"waxing_crescent\": \"Luna crescente\", \n    \"first_quarter\": \"Primo Quarto\",\n    \"waxing_gibbous\": \"Gibbosa crescente\", \n    \"full\": \"Luna piena\",\n    \"full_moon\": \"Luna piena\",\n    \"waning_gibbous\": \"Gibbosa calante\", \n    \"third_quarter\": \"Ultimo quarto\", \n    \"last_quarter\": \"Ultimo quarto\", \n    \"waning_crescent\": \"Luna calante\"\n  }\n}"
  },
  {
    "path": "dist/transl/nl.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"N\",\n    \"NNE\": \"NNO\",\n    \"NE\": \"NO\",\n    \"ENE\": \"ONO\",\n    \"E\": \"O\",\n    \"ESE\": \"OZO\",\n    \"SE\": \"ZO\",\n    \"SSE\": \"ZZO\",\n    \"S\": \"Z\",\n    \"SSW\": \"ZZW\",\n    \"SW\": \"ZW\",\n    \"WSW\": \"WZW\",\n    \"W\": \"W\",\n    \"WNW\":  \"WNW\",\n    \"NW\": \"NW\",\n    \"NNW\": \"NNW\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\": \"Voelt Als\",\n    \"new_moon\": \"Nieuwe maan\",\n    \"new\": \"Nieuwe maan\",\n    \"waxing_crescent\": \"Wassende halve maan\",\n    \"first_quarter\": \"Eerste kwartier\",\n    \"waxing_gibbous\": \"Wassende maan\",\n    \"full\": \"Volle maan\",\n    \"full_moon\": \"Volle maan\",\n    \"waning_gibbous\": \"Afnemende maan\",\n    \"third_quarter\": \"Derde Kwartier\",\n    \"last_quarter\": \"Laatste Kwartier\",\n    \"waning_crescent\": \"Afnemende halve maan\"\n  }\n}"
  },
  {
    "path": "dist/transl/no-NO.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"N\",\n    \"NNE\": \"NNØ\",\n    \"NE\": \"NØ\",\n    \"ENE\": \"ØNØ\",\n    \"E\": \"Ø\",\n    \"ESE\": \"ØSØ\",\n    \"SE\": \"SØ\",\n    \"SSE\": \"SSØ\",\n    \"S\": \"S\",\n    \"SSW\": \"SSV\",\n    \"SW\": \"SV\",\n    \"WSW\": \"VSV\",\n    \"W\": \"V\",\n    \"WNW\": \"VNV\",\n    \"NW\": \"NV\",\n    \"NNW\": \"NNV\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Føles som\",\n    \"new_moon\": \"Nymåne\",\n    \"new\": \"Nymåne\",\n    \"waxing_crescent\": \"Tiltagende halvmåne\",\n    \"first_quarter\": \"Første kvartal\",\n    \"waxing_gibbous\": \"Tiltagende måne\",\n    \"full\": \"Fullmåne\",\n    \"full_moon\": \"Fullmåne\",\n    \"waning_gibbous\": \"Avtagende måne\",\n    \"third_quarter\": \"Tredje kvartal\",\n    \"last_quarter\": \"Sidste kvartal\",\n    \"waning_crescent\": \"Avtagende halvmåne\"\n  }\n}"
  },
  {
    "path": "dist/transl/pt.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"N\",\n    \"NNE\": \"NNE\",\n    \"NE\": \"NE\",\n    \"ENE\": \"ENE\",\n    \"E\": \"E\",\n    \"ESE\": \"ESE\",\n    \"SE\": \"SE\",\n    \"SSE\": \"SSE\",\n    \"S\": \"S\",\n    \"SSW\": \"SSW\",\n    \"SW\": \"SW\",\n    \"WSW\": \"WSW\",\n    \"W\": \"W\",\n    \"WNW\": \"WNW\",\n    \"NW\": \"NW\",\n    \"NNW\": \"NNW\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Sentida\",\n    \"new_moon\": \"Lua Nova\",\n    \"new\": \"Lua nova\",\n    \"waxing_crescent\": \"Lua Crescente\",\n    \"first_quarter\": \"Quarto Crescente\",\n    \"waxing_gibbous\": \"Crescente Gibosa\",\n    \"full\": \"Lua Cheia\",\n    \"full_moon\": \"Lua Cheia\",\n    \"waning_gibbous\": \"Minguante Gibosa\",\n    \"third_quarter\": \"Quarto Minguante\",\n    \"last_quarter\": \"Quarto Minguante\",\n    \"waning_crescent\": \"Lua Minguante\"\n  }\n}"
  },
  {
    "path": "dist/transl/ru.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"С\",\n    \"NNE\": \"ССВ\",\n    \"NE\": \"СВ\",\n    \"ENE\": \"ВСВ\",\n    \"E\": \"В\",\n    \"ESE\": \"ВЮВ\",\n    \"SE\": \"ЮВ\",\n    \"SSE\": \"ЮЮВ\",\n    \"S\": \"Ю\",\n    \"SSW\": \"ЮЮЗ\",\n    \"SW\": \"ЮЗ\",\n    \"WSW\": \"ЗЮЗ\",\n    \"W\": \"З\",\n    \"WNW\": \"ЗСЗ\",\n    \"NW\": \"СЗ\",\n    \"NNW\": \"ССЗ\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Ощущается как\",\n    \"new_moon\": \"Новолуние\",\n    \"new\": \"Новолуние\",\n    \"waxing_crescent\": \"Растущий серп\",\n    \"first_quarter\": \"Первая четверть\",\n    \"waxing_gibbous\": \"Растущая луна\",\n    \"full\": \"Полнолуние\",\n    \"full_moon\": \"Полнолуние\",\n    \"waning_gibbous\": \"Убывающая луна\",\n    \"third_quarter\": \"Третья четверть\",\n    \"last_quarter\": \"Последняя четверть\",\n    \"waning_crescent\": \"Убывающая луна\"\n  }\n}"
  },
  {
    "path": "dist/transl/sr-latn.json",
    "content": "{\n  \"cwcLocWindDirections\": {\n    \"N\": \"S\",\n    \"NNE\": \"SSI\",\n    \"NE\": \"SI\",\n    \"ENE\": \"ISI\",\n    \"E\": \"I\",\n    \"ESE\": \"IJI\",\n    \"SE\": \"JI\",\n    \"SSE\": \"JJI\",\n    \"S\": \"J\",\n    \"SSW\": \"JJZ\",\n    \"SW\": \"JZ\",\n    \"WSW\": \"ZSZ\",\n    \"W\": \"Z\",\n    \"WNW\": \"ZSZ\",\n    \"NW\": \"SZ\",\n    \"NNW\": \"SSZ\"\n  },\n\n  \"cwcTerms\": {\n    \"Feels Like\" : \"Subjektivni osećaj\",\n    \"new_moon\": \"Mlad mesec\",\n    \"new\": \"Mlad mesec\",\n    \"waxing_crescent\": \"Prva osmina\",\n    \"first_quarter\": \"Prva četvrt\",\n    \"waxing_gibbous\": \"Treća osmina\",\n    \"full\": \"Pun mesec\",\n    \"full_moon\": \"Pun mesec\",\n    \"waning_gibbous\": \"Peta osmina\",\n    \"third_quarter\": \"Treća četvrtina\",\n    \"last_quarter\": \"Zadnja četvrtina\",\n    \"waning_crescent\": \"Sedma osmina\"\n  }\n}"
  },
  {
    "path": "hacs.json",
    "content": "{\n  \"name\": \"HA (Lovelace) Card Weather Conditions\",\n  \"domains\": [\"weather\"],\n  \"render_readme\": false,\n  \"filename\": \"ha-card-weather-conditions.js\"\n}"
  },
  {
    "path": "info.md",
    "content": "# Weather Conditions Card\nha-card-weather-conditions is a powerful and flexible Lovelace card for Home Assistant. It integrates a variety of weather-related data sources to present a comprehensive summary and forecast.<br>\n\n[![hacs_badge](https://img.shields.io/badge/HACS-Default-orange.svg)](https://github.com/hacs/integration)\n\n[![License][license-shield]](LICENSE)\n[![Total alerts](https://img.shields.io/lgtm/alerts/g/r-renato/ha-card-weather-conditions.svg?logo=lgtm&logoWidth=18)](https://lgtm.com/projects/g/r-renato/ha-card-weather-conditions/alerts/)\n[![Language grade: JavaScript](https://img.shields.io/lgtm/grade/javascript/g/r-renato/ha-card-weather-conditions.svg?logo=lgtm&logoWidth=18)](https://lgtm.com/projects/g/r-renato/ha-card-weather-conditions/context:javascript)\n\n[![BuyMeCoffee][buymecoffeebadge]][buymecoffee]\n\n## Features\n\n* Current and forecast weather conditions\n* Marine forecast (swell, wave, wind)\n* Ultraviolet radiation index and protection advice\n* Pollen level display (tree, weed, grass)\n* Air quality index with multiple pollutant types\n* Weather alerts (fire, storm, hydrogeological, hydraulic)\n* Meteogram and camera integration\n* Multilingual support\n* Display MeteoAlarm (Early Warnings for Europe) and Dipartimento Protezione Civile (Italy only) Alert\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-overview.png\" width=\"100%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n<!-- <p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-full.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-1.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-2.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>     -->\n\n## **Card Configuration**\n\nTo use the ```ha-card-weather-conditions``` card, add the following configuration to your ```lovelace``` dashboard:\n\n```yaml\nresources:\n  # Required: Load the card if installed via HACS\n  - url: /hacsfiles/ha-card-weather-conditions/ha-card-weather-conditions.js\n    type: module\n  # Optional: Load Card Mod to enable advanced styling/customization\n  - url: /hacsfiles/lovelace-card-mod/card-mod.js\n    type: module\n  # ...\n```\n\n## **Card Schema Summary**\n\n| **Parameter** | **Type**  | **Required** | **Default** | **Description**                                                                                            |\n| ------------- | --------- | ------------ | ----------- | ---------------------------------------------------------------------------------------------------------- |\n| `type`        | `string`  | Yes          | —           | Must be set to `custom:ha-card-weather-conditions`.                                                        |\n| `language`    | `string`  | No           | `en`        | Language for labels. Supported values: `en`, `it`, `nl`, `es`, `de`, `fr`, `sr-latn`, `pt`, `da`, `no-NO`, `cs`. |\n| `weather`     | `object`  | No           | —           | Configuration for main weather source. See dedicated section.                                              |\n| `ultraviolet` | `object`  | No           | —           | Configuration for UV index display. See dedicated section for details.                                     |\n| `pollen`      | `object`  | No           | —           | Configuration for pollen levels. See dedicated section.                                                    |\n| `airquality`  | `object`  | No           | —           | Configuration for air quality index. See dedicated section.                                                |\n| `camera`      | `string`  | No           | —           | Entity ID of the camera to display.                                                                        |\n\n## **1 `weather` Object Schema**\nThe following parameters configure the weather object to display current conditions, short-term and long-term forecasts, as well as related alerts.\nThis card has been tested with weather data provided by `pirateweather`, `climacell`, `darksky` and `openweathermap` integrations.\n| **Name**                  | **Type**  | **Required** | **Default**     | **Description**                                                                                                            |\n| ------------------------- | --------- | ------------ | --------------- | -------------------------------------------------------------------------------------------------------------------------- |\n| `name`                    | `string`  | No           | —               | Name of the location displayed in the summary section.                                                                     |\n| `sun`                     | `string`  | No           | —               | Entity ID for the sun sensor (used to adjust visuals for daylight, sunrise, and sunset).                                   |\n| `moonphase`               | `string`  | No           | —               | Entity ID for the moon phase sensor.                                                                                       |\n| `icons_model`             | `string`  | **Yes**      | `pirateweather` | Icon set to use. Supported values: `pirateweather`, `climacell`, `darksky`, `openweathermap`, `buienradar`, `defaulthass`. |\n| `animation`               | `boolean` | No           | `false`         | Enables visual effects like moving clouds, rain, or waves based on weather conditions.                                     |\n| `present`                 | `object`  | No           | —               | Object containing current weather data (e.g., temperature, humidity, pressure).                                            |\n| `daily_forecasts`         | `object`  | No           | —               | Object containing multi-day weather forecast data.                                                                         |\n| `hourly_forecasts`        | `object`  | No           | —               | Object containing hourly weather forecast data.                                                                            |\n| `marine_daily_forecasts`  | `object`  | No           | —               | Object with daily marine forecast data (e.g., wave height, wind, tides).                                                   |\n| `marine_hourly_forecasts` | `object`  | No           | —               | Object with hourly marine forecast data.                                                                                   |\n| `meteoalarm`              | `string`  | No           | —               | Entity ID from [Meteoalarm](https://meteoalarm.org/) integration for regional weather warnings.                            |\n| `dpcalarm`                | `object`  | No           | —               | Object providing DPC (Protezione Civile) alerts such as thunderstorm or flood risks.                                       |\n\n### **1.1 `present` Object Schema**\nThe present object defines the entities used to display the current weather conditions in the summary section of the card. Each property corresponds to a specific sensor or attribute providing real-time environmental data.\n| **Name**                    |  **Type**  | **Required** | **Default** | **Description**                                                               |\n| --------------------------- | ---------- | ------------ | ----------- | ----------------------------------------------------------------------------- |\n| `condition`                 | `string`   | No           | —           | Entity ID providing the current weather condition (e.g. sunny, cloudy, rain). |\n| `temperature`               | `string`   | No           | —           | Entity ID providing the current temperature.                                  |\n| `temperature_feelslike`     | `string`   | No           | —           | Entity ID providing the perceived (feels-like) temperature.                   |\n| `temperature_min`           | `string`   | No           | —           | Entity ID providing the minimum temperature of the day.                       |\n| `temperature_max`           | `string`   | No           | —           | Entity ID providing the maximum temperature of the day.                       |\n| `humidity`                  | `string`   | No           | —           | Entity ID providing the current humidity level (%).                           |\n| `pressure`                  | `string`   | No           | —           | Entity ID providing the current atmospheric pressure.                         |\n| `visibility`                | `string`   | No           | —           | Entity ID providing the current visibility level.                             |\n| `wind_bearing`              | `string`   | No           | —           | Entity ID providing the wind direction in degrees.                            |\n| `wind_speed`                | `string`   | No           | —           | Entity ID providing the wind speed.                                           |\n| `precipitation_intensity`   | `string`   | No           | —           | Entity ID providing the precipitation rate (e.g. mm/h).                       |\n| `precipitation_probability` | `string`   | No           | —           | Entity ID providing the probability of precipitation (%).                     |\n\n### **1.2 `daily_forecasts` Object Schema**\nThis object defines the structure for multi-day forecast data, where each property can include multiple time slots (e.g. day_1, day_2, day_3…).\n| **Name**                    | **Type**     | **Required** | **Default** | **Description**                                                            |\n| --------------------------- | ------------ | ------------ | ----------- | -------------------------------------------------------------------------- |\n| `condition`                 | `iTimeSlots` | No           | —           | Object containing the weather condition icons or states for each day slot. |\n| `temperature_high`          | `iTimeSlots` | No           | —           | Object containing the daily high temperature values per slot.              |\n| `temperature_low`           | `iTimeSlots` | No           | —           | Object containing the daily low temperature values per slot.               |\n| `precipitation_intensity`   | `iTimeSlots` | No           | —           | Object with the forecasted precipitation amount for each slot.             |\n| `precipitation_probability` | `iTimeSlots` | No           | —           | Object with the probability of precipitation (%) per slot.                 |\n\n### **1.3 `hourly_forecasts` Object Schema**\nThis object defines the structure for hourly weather forecast data. All fields are optional and do not have default values.\n| **Name**                    | **Type**     | **Required** | **Default** | **Description**                                                               |\n| --------------------------- | ------------ | ------------ | ----------- | ----------------------------------------------------------------------------- |\n| `condition`                 | `iTimeSlots` | No           | —           | Object containing the weather condition icons or states for each hourly slot. |\n| `temperature`               | `iTimeSlots` | No           | —           | Object containing the perceived ambient temperature for each hour.            |\n| `temperature_feelslike`     | `iTimeSlots` | No           | —           | Object containing the \"feels like\" temperature values for each hour.          |\n| `precipitation_intensity`   | `iTimeSlots` | No           | —           | Object with forecasted precipitation amount per hour.                         |\n| `precipitation_probability` | `iTimeSlots` | No           | —           | Object with probability of precipitation (%) per hour.                        |\n| `wind_bearing`              | `iTimeSlots` | No           | —           | Object with wind direction (in degrees or cardinal direction) per hour.       |\n| `wind_speed`                | `iTimeSlots` | No           | —           | Object with wind speed values per hour.                                       |\n\n### **1.3.1 `iTimeSlots` Object Schema**\nThis object represents a set of six time slots used to store sequential forecast data (e.g., hourly, daily, etc.).\n| **Name** | **Type** | **Required** | **Description**                                              |\n| -------- | -------- | ------------ | ------------------------------------------------------------ |\n| `slot1`  | `string` | No           | Value for the first time slot (e.g., current or first hour). |\n| `slot2`  | `string` | No           | Value for the second time slot.                              |\n| `slot3`  | `string` | No           | Value for the third time slot.                               |\n| `slot4`  | `string` | No           | Value for the fourth time slot.                              |\n| `slot5`  | `string` | No           | Value for the fifth time slot.                               |\n| `slot6`  | `string` | No           | Value for the sixth time slot.                               |\n\n### **1.4 `dpcalarm` Object Schema**\nThe `dpcalarm` object is used to configure weather-related alerts provided by the Italian Civil Protection Department (DPC), including thunderstorms, hydraulic, and hydrogeological risks. Each property should reference a specific sensor entity ID.\n| **Name**          | **Type** | **Required** | **Description**                                                              |\n| ----------------- | -------- | ------------ | ---------------------------------------------------------------------------- |\n| `thunderstorms`   | `string`   | No           | Entity ID providing thunderstorm alert information from DPC.                 |\n| `hydraulic`       | `string`   | No           | Entity ID providing hydraulic (river/stream flooding) alert information.     |\n| `hydrogeological` | `string`   | No           | Entity ID providing hydrogeological (landslide/soil instability) alert data. |\n\n## **2 `ultraviolet` Object Schema**\nThe ultraviolet object allows you to display UV-related data such as the current index, ozone level, protection window, and safe exposure times for different skin types (I–VI).\n| **Name**            | **Type** | **Required** | **Description**                                                                 |\n| ------------------- | -------- | ------------ | ------------------------------------------------------------------------------- |\n| `protection_window` | `string` | No           | Entity ID providing the time window during which sun protection is recommended. |\n| `ozone_level`       | `string` | No           | Entity ID providing the current atmospheric ozone level.                        |\n| `uv_index`          | `string` | No           | Entity ID providing the current UV index value.                                 |\n| `uv_level`          | `string` | No           | Entity ID describing the UV risk level (e.g. low, moderate, high).              |\n| `max_uv_index`      | `string` | No           | Entity ID providing the maximum forecasted UV index for the day.                |\n| `set_skin_type_1`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type I.           |\n| `set_skin_type_2`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type II.          |\n| `set_skin_type_3`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type III.         |\n| `set_skin_type_4`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type IV.          |\n| `set_skin_type_5`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type V.           |\n| `set_skin_type_6`   | `string` | No           | Entity ID providing sun exposure time recommendation for skin type VI.          |\n\n## **3 `pollen` Object Schema**\nThe pollen object provides information about airborne allergens. It defines the range of measured values (`min` and `max`) and includes a list of `entities` describing each pollen type.\n| **Name**   | **Type**        | **Required** | **Description**                                                         |\n| ---------- | --------------- | ------------ | ----------------------------------------------------------------------- |\n| `entities` | `iPollenItem[]` | Yes          | Array of pollen data objects, each representing a specific pollen type. |\n| `min`      | `number`        | Yes          | Minimum expected pollen concentration (used for scaling).               |\n| `max`      | `number`        | Yes          | Maximum expected pollen concentration (used for scaling).               |\n\n## **3.1 `iPollenItem` Object Schema**\nEach `iPollenItem` defines a specific pollen type to be tracked, including a name for display and the corresponding entity ID in Home Assistant.\n| **Name** | **Type** | **Required** | **Description**                                                   |\n| -------- | -------- | ------------ | ----------------------------------------------------------------- |\n| `name`   | `string`   | Yes        | Display name of the pollen type (e.g., “Grass”, “Birch”).         |\n| `entity` | `string`   | Yes        | Home Assistant entity ID providing the pollen concentration data. |\n\n## **4 `airquality` Object Schema**\nThe `airquality` object defines the Home Assistant entity IDs used to monitor various air pollution metrics and EPA health indicators. Each field corresponds to a specific air quality parameter.\n| **Name**                | **Type** | **Required** | **Description**                                                              |\n| ----------------------- | -------- | ------------ | ---------------------------------------------------------------------------- |\n| `pm25`                  | `string` | No           | Entity ID providing PM2.5 (fine particulate matter) concentration.           |\n| `pm10`                  | `string` | No           | Entity ID providing PM10 (coarse particulate matter) concentration.          |\n| `o3`                    | `string` | No           | Entity ID providing Ozone (O₃) concentration.                                |\n| `no2`                   | `string` | No           | Entity ID providing Nitrogen Dioxide (NO₂) concentration.                    |\n| `co`                    | `string` | No           | Entity ID providing Carbon Monoxide (CO) concentration.                      |\n| `so2`                   | `string` | No           | Entity ID providing Sulfur Dioxide (SO₂) concentration.                      |\n| `epa_aqi`               | `string` | No           | Entity ID providing the EPA-computed Air Quality Index.                      |\n| `epa_primary_pollutant` | `string` | No           | Entity ID providing the EPA-designated primary pollutant.                    |\n| `epa_health_concern`    | `string` | No           | Entity ID describing the EPA-assigned health concern level (e.g., moderate). |\n\n## **Card Layers Sample**\nThis section showcases a complete example of the different visual layers supported by the `ha-card-weather-conditions` card.\nEach layer such as summary, weather conditions, air quality, UV index, and alerts—can be configured independently, allowing full control over how and where data appears.\n\nUse this reference as a guide when designing your Lovelace configuration to build a fully personalized weather dashboard.\n\n### **Summary Layer**\nThe summary layers present a concise visual overview of current weather conditions.\n\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-summary.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  name: \"Acquafredda\" \n  icons_model: pirateweather\n  moonphase: sensor.moon_phase\n  present:\n    condition: sensor.home_condition\n    temperature: sensor.home_temperature\n    temperature_feelslike: sensor.home_apparent_temperature\n```\n\n### **Present Layer**\nThis layer displays the current weather conditions using entity data such as temperature, humidity, wind, and more.\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-present.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  sun: sun.sun\n  present:\n    temperature_min: sensor.home_temperature_min\n    temperature_max: sensor.home_temperature_max\n    humidity: sensor.home_relative_humidity\n    pressure: sensor.home_pressure\n    wind_bearing: sensor.home_wind_bearing\n    wind_speed: sensor.home_wind_speed\n    precipitation_intensity: sensor.home_precipitation\n    precipitation_probability: sensor.home_precipitation_probability\n```\n### **Daily Forecast Layer**\nThis layer provides a multi-day weather overview, including expected temperature highs and lows, precipitation probability, and general conditions.\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-daily-forecast.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  daily_forecasts:\n    condition:\n      slot1: sensor.home_daily_forecast_condition_d1\n      slot2: sensor.home_daily_forecast_condition_d2\n      slot3: sensor.home_daily_forecast_condition_d3\n      slot4: sensor.home_daily_forecast_condition_d4                         \n    temperature_high:\n      slot1: sensor.home_daily_forecast_temperature_max_d1\n      slot2: sensor.home_daily_forecast_temperature_max_d2\n      slot3: sensor.home_daily_forecast_temperature_max_d3\n      slot4: sensor.home_daily_forecast_temperature_max_d4\n    temperature_low:\n      slot1: sensor.home_daily_forecast_temperature_min_d1\n      slot2: sensor.home_daily_forecast_temperature_min_d2\n      slot3: sensor.home_daily_forecast_temperature_min_d3\n      slot4: sensor.home_daily_forecast_temperature_min_d4\n    precipitation_probability:\n      slot1: sensor.home_daily_forecast_precipitation_probability_d1\n      slot2: sensor.home_daily_forecast_precipitation_probability_d2\n      slot3: sensor.home_daily_forecast_precipitation_probability_d3\n      slot4: sensor.home_daily_forecast_precipitation_probability_d4\n    precipitation_intensity:\n      slot1: sensor.home_daily_forecast_precipitation_d1\n      slot2: sensor.home_daily_forecast_precipitation_d2\n      slot3: sensor.home_daily_forecast_precipitation_d3\n      slot4: sensor.home_daily_forecast_precipitation_d4\n```\n\n### **Hourly Forecast Layer**\nThis layer displays detailed weather data for the next several hours, including temperature, precipitation, and wind conditions.\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-hourly-forecast.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  hourly_forecasts:\n    condition:\n      slot1: sensor.home_hourly_forecast_condition_h1\n      slot2: sensor.home_hourly_forecast_condition_h2\n      slot3: sensor.home_hourly_forecast_condition_h3\n      slot4: sensor.home_hourly_forecast_condition_h4\n    temperature:\n      slot1: sensor.home_hourly_forecast_temperature_h1\n      slot2: sensor.home_hourly_forecast_temperature_h2\n      slot3: sensor.home_hourly_forecast_temperature_h3\n      slot4: sensor.home_hourly_forecast_temperature_h4\n    temperature_feelslike:\n      slot1: sensor.home_hourly_forecast_apparent_temperature_h1\n      slot2: sensor.home_hourly_forecast_apparent_temperature_h2\n      slot3: sensor.home_hourly_forecast_apparent_temperature_h3\n      slot4: sensor.home_hourly_forecast_apparent_temperature_h4\n    precipitation_intensity:\n      slot1: sensor.home_hourly_forecast_precipitation_h1\n      slot2: sensor.home_hourly_forecast_precipitation_h2\n      slot3: sensor.home_hourly_forecast_precipitation_h3\n      slot4: sensor.home_hourly_forecast_precipitation_h4\n    precipitation_probability:\n      slot1: sensor.home_hourly_forecast_precipitation_probability_h1\n      slot2: sensor.home_hourly_forecast_precipitation_probability_h2\n      slot3: sensor.home_hourly_forecast_precipitation_probability_h3\n      slot4: sensor.home_hourly_forecast_precipitation_probability_h4\n    wind_bearing:\n      slot1: sensor.home_hourly_forecast_wind_bearing_h1\n      slot2: sensor.home_hourly_forecast_wind_bearing_h2\n      slot3: sensor.home_hourly_forecast_wind_bearing_h3\n      slot4: sensor.home_hourly_forecast_wind_bearing_h4\n    wind_speed:\n      slot1: sensor.home_hourly_forecast_wind_speed_h1\n      slot2: sensor.home_hourly_forecast_wind_speed_h2\n      slot3: sensor.home_hourly_forecast_wind_speed_h3\n      slot4: sensor.home_hourly_forecast_wind_speed_h4\n```\n### **Marine Daily Forecast Layer**\nThis layer provides daily marine weather forecasts, including information such as wave height, wind speed, and sea conditions.\n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-marine-daily-forecast.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  marine_daily_forecasts:\n    wave_height_max:\n      slot1: sensor.marine_wave_height_max_day_0\n      slot2: sensor.marine_wave_height_max_day_1\n      slot3: sensor.marine_wave_height_max_day_2\n      slot4: sensor.marine_wave_height_max_day_3\n    wave_direction:\n      slot1: sensor.marine_wave_direction_dominant_day_0\n      slot2: sensor.marine_wave_direction_dominant_day_1\n      slot3: sensor.marine_wave_direction_dominant_day_2\n      slot4: sensor.marine_wave_direction_dominant_day_3                            \n    swell_wave_height_max:\n      slot1: sensor.amarine_swell_wave_height_max_day_0\n      slot2: sensor.marine_swell_wave_height_max_day_1\n      slot3: sensor.marine_swell_wave_height_max_day_2\n      slot4: sensor.marine_swell_wave_height_max_day_3                              \n    wind_wave_height_max:\n      slot1: sensor.marine_wind_wave_height_max_day_0\n      slot2: sensor.marine_wind_wave_height_max_day_1\n      slot3: sensor.marine_wind_wave_height_max_day_2\n      slot4: sensor.marine_wind_wave_height_max_day_3 \n```\n### **Alarms Layer**\nThis layer displays weather alerts and warnings from official sources such as Meteoalarm and the Italian Civil Protection Department (DPC). \n\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-alarms.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nweather:\n  icons_model: pirateweather\n  meteoalarm: binary_sensor.italy_basilicata_meteo_alarm\n  dpcalarm:\n    thunderstorms: binary_sensor.dpc_basilicata_temporali_oggi\n    hydraulic: binary_sensor.dpc_basilicata_idraulico_oggi\n    hydrogeological: binary_sensor.dpc_basilicata_idrogeologico_oggi\n```\n### **Ultraviolet Layer**\nThis layer presents real-time ultraviolet (UV) radiation data, including UV index levels, ozone concentration, and skin protection recommendations.\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-ultraviolet.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nultraviolet:\n  protection_window: binary_sensor.openuv_protection_window\n  ozone_level: sensor.openuv_current_ozone_level\n  uv_index: sensor.openuv_current_uv_index\n  uv_level: sensor.openuv_current_uv_level\n  max_uv_index: sensor.openuv_max_uv_index\n\n  set_skin_type_1: sensor.openuv_skin_type_1_safe_exposure_time\n  set_skin_type_2: sensor.openuv_skin_type_2_safe_exposure_time\n  set_skin_type_3: sensor.openuv_skin_type_3_safe_exposure_time\n  set_skin_type_4: sensor.openuv_skin_type_4_safe_exposure_time\n  set_skin_type_5: sensor.openuv_skin_type_5_safe_exposure_time\n  set_skin_type_6: sensor.openuv_skin_type_6_safe_exposure_time\n```\n### **Pollen Layer**\nThis layer displays information about airborne pollen levels, helping users monitor potential allergen exposure.\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-pollen.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \npollen:\n  min: 1\n  max: 4\n  entities:\n    - name: Alder\n      entity: sensor.openmeteo_pollen_alder_level \n    - name: Birch\n      entity: sensor.openmeteo_pollen_birch_level\n    - name: Grass\n      entity: sensor.openmeteo_pollen_grass_level\n    - name: Mugwort\n      entity: sensor.openmeteo_pollen_mugwort_level\n    - name: Olive\n      entity: sensor.openmeteo_pollen_olive_level \n    - name: Ragweed\n      entity: sensor.openmeteo_pollen_ragweed_level  \n```\n### **Air Quality Layer**\nThis layer presents real-time data on key air quality indicators such as PM2.5, PM10, ozone, and nitrogen dioxide levels.\n<p float=\"left\">\n<img src=\"https://github.com/r-renato/ha-card-weather-conditions/raw/master/md.images/ha-card-weather-condition-air-quality.png\" width=\"40%\" height=\"auto\" alt=\"Home Assistant lovelace card\">\n</p>\n\n#### **YAML example**\n```yaml\ntype: custom:ha-card-weather-conditions\nlanguage: it \nairquality:\n  pm25: sensor.lazio_italy_pm2_5\n  pm10: sensor.lazio_italy_pm10\n  o3: sensor.roma_lazio_italy_ozone\n  co: sensor.roma_lazio_italy_carbon_monoxide\n  epa_aqi: sensor.lazio_italy_air_quality_index\n  epa_primary_pollutant: sensor.lazio_italy_dominant_pollutant\n```\n\n[license-shield]:https://img.shields.io/github/license/r-renato/ha-card-weather-conditions\n[buymecoffee]: https://www.buymeacoffee.com/0D3WbkKrn\n[buymecoffeebadge]: https://img.shields.io/badge/buy%20me%20a%20coffee-donate-yellow?style=for-the-badge\n"
  },
  {
    "path": "package.json",
    "content": "{\n  \"name\": \"ha-card-weather-conditions\",\n  \"version\": \"2.0.0\",\n  \"description\": \"Home Assistant lovelace card for display weather data.\",\n  \"keywords\": [\n    \"home-assistant\",\n    \"homeassistant\",\n    \"hass\",\n    \"automation\",\n    \"lovelace\",\n    \"custom-cards\",\n    \"weather\"\n  ],\n  \"homepage\": \"https://github.com/r-renato/ha-card-weather-conditions#readme\",\n  \"module\": \"ha-card-weather-conditions.js\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git+ssh://git@github.com/r-renato/ha-card-weather-conditions.git\"\n  },\n  \"author\": \"Renato Rossi\",\n  \"license\": \"MIT\",\n  \"dependencies\": {\n    \"@material/mwc-select\": \"^0.27.0\",\n    \"@material/mwc-textfield\": \"^0.27.0\",\n    \"color\": \"^4.2.3\",\n    \"custom-card-helpers\": \"^1.0.8\",\n    \"hammerjs\": \"^2.0.8\",\n    \"home-assistant-js-websocket\": \"^9.4.0\",\n    \"lit\": \"^3.2.1\",\n    \"memoize-one\": \"^6.0.0\",\n    \"object-hash\": \"^3.0.0\",\n    \"sortablejs\": \"^1.15.6\",\n    \"superstruct\": \"^2.0.2\"\n  },\n  \"devDependencies\": {\n    \"@babel/core\": \"^7.24.0\",\n    \"@rollup/plugin-babel\": \"^6.0.4\",\n    \"@rollup/plugin-commonjs\": \"^28.0.3\",\n    \"@rollup/plugin-json\": \"^6.1.0\",\n    \"@rollup/plugin-node-resolve\": \"^15.2.3\",\n    \"@rollup/plugin-terser\": \"^0.4.4\",\n    \"@rollup/plugin-typescript\": \"^11.1.5\",\n    \"@typescript-eslint/eslint-plugin\": \"^6.21.0\",\n    \"@typescript-eslint/parser\": \"^6.21.0\",\n    \"eslint\": \"^8.56.0\",\n    \"eslint-config-airbnb-base\": \"^15.0.0\",\n    \"eslint-plugin-import\": \"^2.29.1\",\n    \"prettier\": \"^3.2.5\",\n    \"rollup\": \"^4.12.0\",\n    \"rollup-plugin-execute\": \"^1.1.1\",\n    \"typescript\": \"5.3.3\"\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/r-renato/ha-card-weather-conditions/issues\"\n  },\n  \"main\": \"index.js\",\n  \"scripts\": {\n    \"watch\": \"rollup -c --watch\",\n    \"build\": \"npm run lint && npm run rollup -- --config rollup.config.mjs\",\n    \"build:new\": \"npm run lint && npm run rollup -- --config rollup.new.config.mjs\",\n    \"lint\": \"eslint src/*.ts\",\n    \"rollup\": \"rollup --no-compact \"\n  }\n}\n"
  },
  {
    "path": "rollup.new.config.mjs",
    "content": "import resolve from '@rollup/plugin-node-resolve'; // ✅ nuovo package\nimport typescript from '@rollup/plugin-typescript'; // ✅ moderno\nimport babel from '@rollup/plugin-babel';\nimport terser from '@rollup/plugin-terser'; // ✅ va destrutturato\nimport execute from 'rollup-plugin-execute'; // ancora valido\nimport commonjs from '@rollup/plugin-commonjs'; // 👈 nuovo import\n\nexport default {\n    input: 'src/ha-weather-ecard.ts',\n    output: {\n        //dir: './dist',\n        file: 'dist/ha-card-weather-conditions.js', // 👈 nome file forzato\n        format: 'esm',\n        sourcemap: 'inline',\n        banner: false,\n        // comments: false\n    },\n    plugins: [\n        resolve({\n            browser: true, // 👈 molto importante per card frontend\n            exportConditions: ['browser']\n        }),\n        commonjs(), // 👈 serve per convertire eventuali commonjs a es6\n        typescript({\n            tsconfig: './tsconfig.json'\n        }),\n        babel({\n            babelHelpers: 'bundled',\n            exclude: 'node_modules/**',\n            extensions: ['.js', '.ts']\n        }),\n        terser(),\n        execute([\n            `echo \"$(date '+%d/%m/%Y %H:%M:%S') rollup done.\" ; echo -e '\\\\007'`\n        ])\n    ]\n};\n"
  },
  {
    "path": "src/base/lovelace-base.ts",
    "content": "/* eslint-disable no-underscore-dangle */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n  css,\n  CSSResultGroup,\n  html,\n  LitElement,\n  PropertyValues,\n  TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { HomeAssistant } from 'custom-card-helpers';\n\nimport { defaultColorCss, defaultDarkColorCss } from '../utils/colors';\nimport { iCardConfig, iLovelaceCardConfig } from '../utils/config-schema';\nimport {\n  cwcLocale,\n  hacsImagePath,\n  logo,\n  manImagePath,\n  optConsoleParam1,\n  optConsoleParam2,\n  optConsoleParam3,\n} from '../utils/const';\nimport {\n  getIconModelData,\n  imageExist,\n  loadJSON,\n  logInfo,\n} from '../utils/helper';\nimport { cwcClimacellDayIcons, cwcClimacellNightIcons } from '../iconmodels/im-climacell';\nimport { getCardStyles } from '../utils/helper-render';\nimport { cwcDaytimePirateWeatherIcons, cwcNightlyPirateWeaterIcons } from '../iconmodels/im-pirateweather';\n\nexport interface iTerms {\n   windDirections: string;\n   words: Record<string, string>;\n}\n\nexport interface iIconsConfig {\n  path: string ;\n  iconType: string ;\n  icons_model: string ;\n  iconsDay: { [key: string]: string; } ;\n  iconsNight: { [key: string]: string; } ;\n}\n\nexport interface iLovelaceCard extends HTMLElement {\n  hass?: HomeAssistant;\n  isPanel?: boolean;\n  editMode?: boolean;\n  getCardSize(): number | Promise<number>;\n  setConfig(config: iLovelaceCardConfig): void;\n}\n\nexport function computeDarkMode(hass?: HomeAssistant): boolean {\n  if (!hass) return false;\n  return (hass.themes as any).darkMode as boolean;\n}\n\n/* -------------------- VARIABILI GLOBALI -------------------- */\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n// let loadedTranslations: any[] = [];\n// let resolvedImagePath: string | null = null;\n\nexport async function preloadResources(): Promise<{ translations: any[]; imagePath: string | null }> {\n  const [hacsResult, manResult] = await Promise.all([\n    imageExist(`${hacsImagePath}/static/cloudy.svg`),\n    imageExist(`${manImagePath}/static/cloudy.svg`),\n  ]);\n\n  let imagePath: string | null = null;\n\n  if (hacsResult) {\n    imagePath = hacsImagePath;\n  } else if (manResult) {\n    imagePath = manImagePath;\n  } else {\n    imagePath = null;\n  }\n\n  if (!imagePath) {\n    logInfo(`${logo} - Impossibile determinare il path immagini.`);\n    return { translations: [], imagePath: null };\n  }\n\n  const langs = ['en', 'it', 'nl', 'es', 'de', 'fr', 'sr-latn', 'pt', 'da', 'no-NO', 'cs'];\n  const translPath = `${imagePath}/../transl/`;\n  const translations = await Promise.all(langs.map((lang) => loadJSON(`${translPath}${lang}.json`)));\n\n  return { translations, imagePath };\n}\n\nexport abstract class LovelaceBaseElement extends LitElement {\n  @property({ attribute: false }) public hass!: HomeAssistant;\n\n  @property({ attribute: false }) protected _config?: iCardConfig;\n\n  public isPanel?: boolean = false;\n\n  public editMode?: boolean = false;\n\n  public invalidConfig: boolean = false;\n\n  protected _iconsConfig: iIconsConfig;\n\n  protected _imagesPath: string;\n\n  protected _name: string;\n\n  protected _language: string;\n\n  protected _translations: string[];\n\n  protected _terms: iTerms;\n\n  protected _hasPresent: boolean = false;\n\n  protected _hasDailyForecasts: boolean = false;\n\n  protected _hasHourlyForecasts: boolean = false;\n\n  protected _hasMarineDailyForecasts: boolean = false;\n\n  protected _hasMarineHourlyForecasts: boolean = false;\n\n  protected _hasMetealarm: boolean = false;\n\n  protected _hasDPCalarm: boolean = false;\n\n  protected _hasMeteogram: boolean = false;\n\n  protected _hasAirQuality: boolean = false;\n\n  protected _hasPollen: boolean = false;\n\n  protected _hasUltraviolet: boolean = false;\n\n  protected _hasAlert: boolean = false;\n\n  protected _hasSea: boolean = false;\n\n  protected _hasCamera: boolean = false;\n\n  protected updated(changedProps: PropertyValues): void {\n    super.updated(changedProps);\n    if (changedProps.has('hass') && this.hass) {\n      const currentDarkMode = computeDarkMode(changedProps.get('hass'));\n      const newDarkMode = computeDarkMode(this.hass);\n      if (currentDarkMode !== newDarkMode) {\n        this.toggleAttribute('dark-mode', newDarkMode);\n      }\n    }\n  }\n\n  static get styles(): CSSResultGroup {\n    return [\n      // animations,\n      css`\n        :host {\n          ${defaultColorCss}\n        }\n        :host([dark-mode]) {\n          ${defaultDarkColorCss}\n        }\n        ${getCardStyles()}\n      `,\n    ];\n  }\n\n  public async setConfig(config: iCardConfig) {\n    if (!config) {\n      this.invalidConfig = true;\n      throw new Error('Invalid configuration');\n    }\n\n    // console.log({ card_config: config });\n\n    if (!this._translations?.length || !this._imagesPath) {\n      const { translations, imagePath } = await preloadResources();\n      this._translations = translations;\n      this._imagesPath = imagePath;\n    }\n\n    this._name = config?.weather?.name ?? undefined;\n    this._language = config.language?.toLowerCase() || 'en';\n\n    this._loadTranslations(this._language);\n    // this._initNumberFormatters(this._language);\n\n    // this._setupDisplaySections(config.display ?? []);\n    this._detectDataSections(config);\n\n    this._setupIcons(config.weather?.icons_model);\n    this._config = config;\n\n    logInfo(`${logo} - Config loaded.`);\n  }\n\n  // eslint-disable-next-line class-methods-use-this\n  public getCardSize(): number | Promise<number> {\n    return 1;\n  }\n\n  private _loadTranslations(lang: string) {\n    try {\n      const transls = JSON.parse(this._translations[cwcLocale[lang]]);\n      this._terms = {\n        windDirections: transls.cwcLocWindDirections,\n        words: transls.cwcTerms,\n      };\n\n      logInfo(\n        `${logo}%c card \"${this._name}\", locale is '${lang}'.`,\n        optConsoleParam1,\n        optConsoleParam2,\n        optConsoleParam3,\n      );\n    } catch (e) {\n      const fallback = 'en';\n      const transls = JSON.parse(this._translations[cwcLocale[fallback]]);\n      this._terms = {\n        windDirections: transls.cwcLocWindDirections,\n        words: transls.cwcTerms,\n      };\n\n      logInfo(\n        `${logo}%c card \"${this._name}\" unable to use '${lang}' locale, set as default '${fallback}'.`,\n        optConsoleParam1,\n        optConsoleParam2,\n        optConsoleParam3,\n      );\n    }\n  }\n\n  private _detectDataSections(config: iCardConfig) {\n    this._hasPresent = !!config.weather?.present;\n    this._hasDailyForecasts = !!config.weather?.daily_forecasts;\n    this._hasHourlyForecasts = !!config.weather?.hourly_forecasts;\n    this._hasMarineDailyForecasts = !!config.weather?.marine_daily_forecasts;\n    this._hasMarineHourlyForecasts = !!config.weather?.marine_hourly_forecasts;\n    this._hasMetealarm = !!config.weather?.meteoalarm;\n    this._hasDPCalarm = !!config.weather?.dpcalarm;\n    // this._hasMeteogram = !!config.weather?.forecast?.meteogram;\n    this._hasAirQuality = !!config.airquality;\n    this._hasPollen = config.pollen && Array.isArray(config.pollen.entities) && config.pollen.entities.length > 0;\n    this._hasUltraviolet = !!config.ultraviolet;\n    this._hasCamera = !!config.camera;\n    // this._hasAlert = !!config.alert;\n  }\n\n  private _setupIcons(iconsModel?: string) {\n    this._iconsConfig = {\n      path: this._imagesPath,\n      iconType: this._config?.weather?.animation ? 'animated' : 'static',\n      icons_model: iconsModel || 'pirateweather',\n      iconsDay: cwcDaytimePirateWeatherIcons,\n      iconsNight: cwcNightlyPirateWeaterIcons,\n    };\n\n    if (iconsModel) {\n      const modelData = getIconModelData(iconsModel);\n      this._iconsConfig.icons_model = modelData.iconsModel;\n      this._iconsConfig.iconsDay = modelData.iconsDay;\n      this._iconsConfig.iconsNight = modelData.iconsNight;\n    }\n  }\n\n  /**\n   * generates the card HTML\n   * @return {TemplateResult}\n   */\n  public render(): TemplateResult {\n    if (this.invalidConfig) {\n      return html`\n        <ha-card class=\"ha-card-weather-conditions\">\n            <div class='banner'>\n                <div class=\"header\">ha-card-weather-conditions</div>\n            </div>\n            <div class='content'>\n                Configuration ERROR!\n            </div>\n        </ha-card>\n    `;\n    }\n\n    return this._render();\n  }\n\n  protected abstract _render(): TemplateResult;\n}\n"
  },
  {
    "path": "src/builder/b-airquality.ts",
    "content": "/* eslint-disable camelcase */\n/* eslint-disable no-else-return */\n/* eslint-disable object-curly-newline */\nimport { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iAirQuality } from '../utils/config-schema';\nimport { getEntityNumericValue, getEntityRawValue, getEntityUnit } from '../utils/helper';\nimport { renderWeatherPresent } from '../templates/t-present';\n\n/**\n * Restituisce un colore (in formato hex) in base al valore dell'indice EPA AQI.\n * @param {number} aqi - Valore AQI compreso tra 0 e 500\n * @returns {string} - Colore esadecimale associato alla fascia AQI\n */\nfunction getAQIColor(aqi: number): string {\n  if (aqi <= 50) {\n    return '#009966'; // Verde (Buona)\n  } else if (aqi <= 100) {\n    return '#ffde33'; // Giallo (Moderata)\n  } else if (aqi <= 150) {\n    return '#ff9933'; // Arancione (Sensibili)\n  } else if (aqi <= 200) {\n    return '#cc0033'; // Rosso (Non salutare)\n  } else if (aqi <= 300) {\n    return '#660099'; // Viola (Molto non salutare)\n  } else {\n    return '#7e0023'; // Marrone scuro (Pericolosa)\n  }\n}\n\nconst buildAirQuality = (\n  hass: HomeAssistant,\n  language: string,\n  airquality: iAirQuality,\n) => {\n  const lang = language || hass.selectedLanguage || hass.language;\n\n  const pm25 = getEntityNumericValue({ entityId: airquality.pm25, hass, lang: language, decimals: 0 });\n  const pm10 = getEntityNumericValue({ entityId: airquality.pm10, hass, lang: language, decimals: 0 });\n  const o3 = getEntityNumericValue({ entityId: airquality.o3, hass, lang: language, decimals: 1 });\n  const no2 = getEntityNumericValue({ entityId: airquality.no2, hass, lang: language, decimals: 0 });\n  const co = getEntityNumericValue({ entityId: airquality.co, hass, lang: language, decimals: 1 });\n  const so2 = getEntityNumericValue({ entityId: airquality.so2, hass, lang: language, decimals: 0 });\n  const epa_aqi = getEntityNumericValue({ entityId: airquality.epa_aqi, hass, lang: language, decimals: 0 });\n  const epa_primary_pollutant = getEntityRawValue(hass, airquality.epa_primary_pollutant);\n\n  const airQualityData = {\n    pm25: {\n      value: (pm25 ? `pm2.5 ${pm25}` : pm25),\n      unit: getEntityUnit(hass, airquality.pm25) || 'µg/m³',\n      icon: 'mdi:weather-hazy',\n    },\n    pm10: {\n      value: (pm10 ? `pm10 ${pm10}` : pm10),\n      unit: getEntityUnit(hass, airquality.pm10) || 'µg/m³',\n      icon: 'mdi:weather-hazy',\n    },\n    o3: {\n      value: (o3 ? `o3 ${o3}` : o3),\n      unit: getEntityUnit(hass, airquality.o3) || 'µg/m³',\n      icon: 'mdi:molecule',\n    },\n    no2: {\n      value: (no2 ? `no2 ${no2}` : no2),\n      unit: getEntityUnit(hass, airquality.no2) || 'µg/m³',\n      icon: 'mdi:molecule',\n    },\n    co: {\n      value: (co ? `co ${co}` : co),\n      unit: getEntityUnit(hass, airquality.co) || 'µg/m³',\n      icon: 'mdi:molecule',\n    },\n    so2: {\n      value: (so2 ? `so2 ${so2}` : so2),\n      unit: getEntityUnit(hass, airquality.so2) || 'µg/m³',\n      icon: 'mdi:molecule',\n    },\n    epa_aqi: {\n      value: (epa_aqi ? `Air Quality Index ${epa_aqi}` : epa_aqi),\n      // unit: getEntityUnit(hass, airquality.epa_aqi) || 'µg/m³',\n      icon: 'mdi:weather-hazy',\n      icon_color: getAQIColor(Number(getEntityRawValue(hass, airquality.epa_aqi))),\n    },\n    epa_primary_pollutant: {\n      value: (epa_primary_pollutant ? `Primary ${epa_primary_pollutant}` : epa_primary_pollutant),\n      // unit: getEntityUnit(hass, airquality.epa_aqi) || 'µg/m³',\n      icon: 'mdi:weather-hazy',\n    },\n  };\n\n  return renderWeatherPresent(airQualityData, lang);\n};\n\nexport default buildAirQuality;\n"
  },
  {
    "path": "src/builder/b-camera.ts",
    "content": "import { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iTerms } from '../base/lovelace-base';\nimport renderCamera from '../templates/t-camera';\n\nconst buildCamera = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  handlePopup: (e: Event, entityId: string) => void,\n  cameraId: string,\n) => {\n  const camera = cameraId && hass.states[cameraId];\n\n  const entityPicture = camera?.attributes?.entity_picture;\n  const friendlyName = camera?.attributes?.friendly_name ?? cameraId;\n\n  return renderCamera(handlePopup, cameraId, entityPicture, friendlyName);\n};\n\nexport default buildCamera;\n"
  },
  {
    "path": "src/builder/b-meteoalarm.ts",
    "content": "/* eslint-disable camelcase */\n/* eslint-disable quote-props */\nimport { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iTerms } from '../base/lovelace-base';\nimport { iDPCAlert } from '../utils/config-schema';\nimport renderMeteoDPCalarm, { iWeatherMeteoDPCAlarmDataInterface } from '../templates/t-meteoalarm';\nimport { getLocaleInfo } from '../utils/helper';\n\nconst getEffectiveLabel = (effective: string) => {\n  const effectiveDatetime = new Date(effective);\n  const now = new Date();\n\n  // Reset dell'ora per confronto solo a livello di giorno\n  const today = new Date(now.getFullYear(), now.getMonth(), now.getDate());\n  const effectiveDate = new Date(effectiveDatetime.getFullYear(), effectiveDatetime.getMonth(), effectiveDatetime.getDate());\n\n  const msInDay = 24 * 60 * 60 * 1000;\n  const dayDifference = Math.round((effectiveDate.getTime() - today.getTime()) / msInDay);\n\n  let effectiveLabel: 'oggi' | 'domani' | 'dopodomani' | undefined;\n\n  if (dayDifference === 0) {\n    effectiveLabel = 'oggi';\n  } else if (dayDifference === 1) {\n    effectiveLabel = 'domani';\n  } else if (dayDifference === 2) {\n    effectiveLabel = 'dopodomani';\n  } else {\n    effectiveLabel = undefined;\n  }\n  return effectiveLabel;\n};\n\nconst buildMeteoAlarmData = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  meteoalarmId: string,\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n): Record<string, iWeatherMeteoDPCAlarmDataInterface> => {\n  const eventIcon: Record<string, string> = {\n    'wind': 'mdi:weather-windy',\n    'snow-ice': 'mdi:snowflake-alert',\n    'thunderstorm': 'mdi:weather-lightning',\n    'fog': 'mdi:weather-fog',\n    'high-temperature': 'mdi:weather-sunny-alert',\n    'low-temperature': 'mdi:thermometer-low',\n    'coastal-event': 'mdi:home-flood',\n    'forest-fire': 'mdi:pine-tree-fire',\n    'avalanche': 'mdi:image-filter-hdr',\n    'rain': 'mdi:weather-pouring',\n    'flood': 'mdi:home-flood',\n    'rain-flood': 'mdi:weather-pouring',\n    'marine-hazard': 'mdi:weather-hurricane',\n    'drought': 'mdi:water-off',\n  };\n\n  const eventIconColor: Record<string, string> = {\n    green: 'green',\n    yellow: '#ffa600',\n    orange: 'orange',\n    red: 'red',\n  };\n\n  const meteoalarm = meteoalarmId && hass.states[meteoalarmId];\n  if (!meteoalarm?.attributes) return {};\n\n  const fpcData: Record<string, iWeatherMeteoDPCAlarmDataInterface> = {};\n\n  if (meteoalarm.state === 'on' && meteoalarm.attributes) {\n    const localeInfo = getLocaleInfo(lang);\n    const {\n      event,\n      severity,\n      awareness_type,\n      awareness_level,\n      effective,\n    } = meteoalarm.attributes;\n\n    const awarenessType = awareness_type?.split(';')[1]?.trim().toLowerCase() || '';\n    const awarenessLevel = awareness_level?.split(';')[1]?.trim().toLowerCase() || '';\n    const eventName = event || '';\n    const severityLevel = severity?.split(';')[1]?.trim() || '';\n    const effectiveDatetime = getEffectiveLabel(effective);\n\n    fpcData['meteoalarm'] = {\n      event: eventName,\n      severity: severityLevel,\n      icon: eventIcon[awarenessType] || 'mdi:alert',\n      icon_color: eventIconColor[awarenessLevel] || 'grey',\n      datetime: (new Date(effective)).toLocaleDateString(localeInfo.locale, {\n        weekday: 'short',\n        timeZone: localeInfo.timezone,\n      }).toLocaleUpperCase(),\n    };\n  }\n\n  return fpcData;\n};\n\nconst buildDPCAlarmData = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  dpcalarm: iDPCAlert,\n) => {\n  if (!dpcalarm) return {};\n\n  const localeInfo = getLocaleInfo(lang);\n  const eventIconColor = {\n    0: 'gray',\n    1: 'green',\n    2: '#ffa600',\n    3: 'orange',\n    4: 'red',\n  };\n\n  const sources = ['thunderstorms', 'hydraulic', 'hydrogeological'];\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const fpcData: Record<string, iWeatherMeteoDPCAlarmDataInterface> = {};\n\n  sources.forEach((key) => {\n    const entityId = dpcalarm[key as keyof iDPCAlert];\n    const entity = entityId && hass.states[entityId];\n\n    if (entity && entity.state === 'on' && entity.attributes) {\n      const { level, info, icon } = entity.attributes;\n      fpcData[key] = {\n        event: info,\n        severity: level,\n        icon,\n        icon_color: eventIconColor[level],\n        datetime: (new Date()).toLocaleDateString(localeInfo.locale, {\n          weekday: 'short',\n          timeZone: localeInfo.timezone,\n        }).toLocaleUpperCase(),\n      };\n    }\n  });\n  return fpcData;\n};\n\nconst buildMeteoDPCalarm = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  meteoalarmId: string,\n  dpcalarm: iDPCAlert, \n) => {\n  const alarmsData = { ...buildMeteoAlarmData(hass, lang, terms, meteoalarmId), ...buildDPCAlarmData(hass, lang, terms, dpcalarm) };\n  // console.debug('buildMeteoDPCalarm', alarmsData);\n  return renderMeteoDPCalarm(alarmsData);\n};\n\nexport default buildMeteoDPCalarm;\n"
  },
  {
    "path": "src/builder/b-pollen.ts",
    "content": "import { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iPollen } from '../utils/config-schema';\nimport { getEntityRawValue, string2Number } from '../utils/helper';\nimport { iPollenData, renderPollen } from '../templates/t-pollen';\n\nconst buildPollen = (hass: HomeAssistant, lang: string, pollen: iPollen) => {\n  const allItems: iPollenData[] = [];\n  if (Array.isArray(pollen.entities) && pollen.entities.length > 0) {\n    pollen.entities.forEach((item) => {\n      const rawvalue = getEntityRawValue(hass, item.entity);\n      if (rawvalue && rawvalue !== 'unknown' && rawvalue !== 'unavailable') {\n        let value: number = string2Number(getEntityRawValue(hass, item.entity));\n\n        if (Number.isNaN(value) || value < pollen.min || value > pollen.max) {\n          value = 0;\n        }\n\n        allItems.push({\n          name: item.name,\n          value,\n        });\n      }\n      // console.log(`Nome: ${item.name}, Entità: ${item.entity}`);\n    });\n  }\n\n  return renderPollen(allItems, pollen.min, pollen.max);\n};\n\nexport default buildPollen;\n"
  },
  {
    "path": "src/builder/b-present.ts",
    "content": "/* eslint-disable camelcase */\nimport { HomeAssistant } from 'custom-card-helpers/dist';\nimport {\n  getEntityNumericValue,\n  getEntityRawValue,\n  getEntityUnit,\n  getLocaleInfo,\n  getWindDirections,\n} from '../utils/helper';\n// import { getSensorUnit } from '../utils/helper-render';\nimport { renderWeatherPresent } from '../templates/t-present';\nimport { iPresentData } from '../utils/config-schema';\nimport { iTerms } from '../base/lovelace-base';\n\nconst present = (hass: HomeAssistant, language: string, cwcLocWindDirections, presentData: iPresentData, sunId: string) => {\n  const localeInfo = getLocaleInfo(language);\n  const sunEntity = sunId ? hass.states[sunId] : undefined;\n  const { next_rising, next_setting } = sunEntity?.attributes ?? {};\n\n  const next_rising_formatted = next_rising ? new Date(next_rising).toLocaleTimeString(localeInfo.locale, {\n    hour: '2-digit',\n    minute: '2-digit',\n    second: '2-digit',\n    hour12: false,\n    timeZone: localeInfo.timezone,\n  }) : undefined;\n\n  const next_setting_formatted = next_rising ? new Date(next_setting).toLocaleTimeString(localeInfo.locale, {\n    hour: '2-digit',\n    minute: '2-digit',\n    second: '2-digit',\n    hour12: false,\n    timeZone: localeInfo.timezone,\n  }) : undefined;\n\n  return {\n    nextRising: { value: next_rising_formatted, icon: 'mdi:weather-sunset-up' },\n    nextSetting: { value: next_setting_formatted, icon: 'mdi:weather-sunset-down' },\n\n    precipitationIntensity: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.precipitation_intensity, hass, lang: language, decimals: 2 }),\n      unit: getEntityUnit(hass, presentData.precipitation_intensity),\n      icon: 'mdi:weather-rainy',\n    },\n    precipitationProbability: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.precipitation_probability, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.precipitation_probability),\n      icon: 'mdi:weather-rainy',\n    },\n    humidity: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.humidity, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.humidity),\n      icon: 'mdi:water-percent',\n    },\n    windBearing: { value: getWindDirections(getEntityRawValue(hass, presentData.wind_bearing), cwcLocWindDirections) },\n    windSpeed: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.wind_speed, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.wind_speed),\n      icon: 'mdi:weather-windy',\n    },\n    pressure: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.pressure, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.pressure),\n      icon: 'mdi:gauge',\n    },\n    visibility: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.visibility, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.visibility),\n      icon: 'mdi:weather-fog',\n    },\n    temperatureHigh: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.temperature_max, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.temperature_max),\n      icon: 'mdi:thermometer',\n    },\n    temperatureLow: {\n      // eslint-disable-next-line object-curly-newline\n      value: getEntityNumericValue({ entityId: presentData.temperature_min, hass, lang: language, decimals: 0 }),\n      unit: getEntityUnit(hass, presentData.temperature_min),\n      icon: 'mdi:thermometer',\n    },\n  };\n};\n\n// const presentFromForecastData = (hass: HomeAssistant, language: string, forecastCfg: Forecast) => {\n//   const getValue = (obj: Record<string, string>) => {\n//     const [key, entityId] = Object.entries(obj)[0] ?? [];\n//     const state = entityId && hass.states[entityId]?.state;\n//     return state !== undefined ? formatNumber({ stringNumber: state, lang: language, fractionDigits: 0 }) : undefined;\n//   };\n\n//   const {\n//     temperature_high = {},\n//     temperature_low = {},\n//     precipitation_probability = {},\n//     precipitation_intensity = {},\n//   } = forecastCfg;\n\n//   return {\n//     temperatureHigh: { value: getValue(temperature_high), unit: getEntityUnit(hass, temperature_high), icon: 'mdi:thermometer' },\n//     temperatureLow: { value: getValue(temperature_low), unit: getEntityUnit(hass, 'temperature'), icon: 'mdi:thermometer' },\n//     precipitationProbability: { value: getValue(precipitation_probability), unit: '%', icon: 'mdi:weather-rainy' },\n//     precipitationIntensity: { value: getValue(precipitation_intensity), unit: getEntityUnit(hass, 'precipitation'), icon: 'mdi:weather-rainy' },\n//   };\n// };\n\nconst buildWeatherPresent = (\n  hass: HomeAssistant,\n  language: string,\n  terms: iTerms,\n  presentData: iPresentData,\n  sunId: string,\n) => {\n  const lang = language || hass.selectedLanguage || hass.language;\n\n  const presentObj = present(hass, lang, terms.windDirections, presentData, sunId);\n  // const presentFromForecastObj = presentFromForecastData(hass, language, forecastCfg);\n\n  // console.debug('buildWeatherPresent', { presentObj });\n  return renderWeatherPresent({ ...presentObj }, lang);\n};\n\nexport default buildWeatherPresent;\n"
  },
  {
    "path": "src/builder/b-summary.ts",
    "content": "import { HomeAssistant } from 'custom-card-helpers/dist';\n\nimport renderWeatherSummary from '../templates/t-summary';\nimport {\n  getEntityNumericValue,\n  getEntityRawValue,\n  getEntityUnit,\n  translate,\n} from '../utils/helper';\n\nimport { getMoonIcon, getWeatherIcon } from '../utils/helper-render';\nimport { iPresentData } from '../utils/config-schema';\nimport { iIconsConfig, iTerms } from '../base/lovelace-base';\n\nconst buildWeatherSummary = (\n  hass: HomeAssistant,\n  language: string,\n  terms: iTerms,\n  iconsConfig: iIconsConfig,\n  name: string,\n  presentData: iPresentData,\n  sunId: string,\n  moonphase: string,\n) => {\n  const moonPhase = getEntityRawValue(hass, moonphase);\n  const moonIcon: string = moonPhase ? getMoonIcon(moonPhase) : '';\n  const sun = getEntityRawValue(hass, sunId);\n  const currentConditions = getEntityRawValue(hass, presentData.condition)?.toLowerCase() || 'na';\n  // eslint-disable-next-line max-len\n  const temperature = presentData.temperature ? getEntityNumericValue({ entityId: presentData.temperature, hass, lang: language }) ?? undefined : undefined;\n  // eslint-disable-next-line max-len\n  const temperatureFeelsLike = presentData.temperature_feelslike ? getEntityNumericValue({ entityId: presentData.temperature_feelslike, hass, lang: language }) ?? undefined : undefined;\n  const temperatureFeelsLikeIcon = hass.states[presentData.temperature_feelslike]?.attributes.icon ?? '';\n\n  return renderWeatherSummary({\n    title: name ?? undefined, // 'Verkhnenovokutlumbetyevo',\n    moonText: (moonphase ? translate(moonPhase, terms.words) : undefined),\n    moonIcon,\n    conditionText: currentConditions,\n    conditionIcon: getWeatherIcon(currentConditions, iconsConfig, sun),\n    temperature,\n    temperatureUnit: getEntityUnit(hass, presentData.temperature),\n    feelsLikeTerm: translate('Feels Like', terms.words),\n    temperatureFeelsLike,\n    temperatureFeelsLikeIcon,\n  });\n};\n\nexport default buildWeatherSummary;\n"
  },
  {
    "path": "src/builder/b-ultraviolet.ts",
    "content": "import { HomeAssistant } from 'custom-card-helpers/dist';\n\nimport { getEntityNumericValue, getEntityRawValue, pad } from '../utils/helper';\nimport renderUltraviolet from '../templates/t-ultraviolet';\nimport { iUltraviolet } from '../utils/config-schema';\n\n// const getRawValue = (hass: HomeAssistant, entityId?: string): string | undefined => entityId && hass.states[entityId]?.state;\n// const getValue = (hass: HomeAssistant, entityId?: string, lang: string = 'en', decimals = 0): string | undefined => {\n//   const state = entityId && hass.states[entityId]?.state;\n//   return state !== undefined ? formatNumber(state, lang, decimals) : undefined;\n// };\n\nconst getTime = (state?: string | number): string => {\n  const value = typeof state === 'string' && state.toLowerCase() === 'unknown'\n    ? NaN\n    : Number(state);\n  // console.debug(state);\n  if (!Number.isFinite(value) || value < 0) return '--';\n\n  const hours = Math.floor(value / 60);\n  const minutes = value % 60;\n\n  return hours > 0\n    ? `${hours}:${pad(minutes, 2)} h`\n    : `${minutes} m`;\n};\n\nconst summaryData = (hass: HomeAssistant, lang: string, uv: iUltraviolet) => ({\n  protectionWindow: {\n    value: (!getEntityRawValue(hass, uv.protection_window) || getEntityRawValue(hass, uv.protection_window) === 'unknown' ? 'off' :\n      getEntityRawValue(hass, uv.protection_window)\n    ),\n    icon: 'mdi:sunglasses',\n  },\n  currentUVLevel: { value: getEntityRawValue(hass, uv.uv_level), icon: 'mdi:weather-sunny' },\n  currentUVIndex: { value: getEntityNumericValue({ entityId: uv.uv_index, hass, lang }), unit: 'UV Idx', icon: 'mdi:weather-sunny' },\n  maxUVIndex: { value: getEntityNumericValue({ entityId: uv.max_uv_index, hass, lang }), unit: 'UV Idx', icon: 'mdi:weather-sunny' },\n  currentOzoneLevel: { value: getEntityNumericValue({ entityId: uv.ozone_level, hass, lang }), unit: 'DU', icon: 'mdi:vector-triangle' },\n});\n\nconst skinData = (hass: HomeAssistant, lang: string, uv: iUltraviolet) => ({\n  skinType1: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_1, hass, lang })) },\n  skinType2: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_2, hass, lang })) },\n  skinType3: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_3, hass, lang })) },\n  skinType4: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_4, hass, lang })) },\n  skinType5: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_5, hass, lang })) },\n  skinType6: { value: getTime(getEntityNumericValue({ entityId: uv.set_skin_type_6, hass, lang })) },\n});\n\nconst buildUltraviolet = (hass: HomeAssistant, lang: string, uv: iUltraviolet) =>\n  // eslint-disable-next-line implicit-arrow-linebreak\n  renderUltraviolet({ ...summaryData(hass, lang, uv) }, { ...skinData(hass, lang, uv) });\n\nexport default buildUltraviolet;\n"
  },
  {
    "path": "src/builder/b-weather-forecast.ts",
    "content": "import { HomeAssistant } from 'custom-card-helpers/dist';\nimport { getWeatherIcon } from '../utils/helper-render';\nimport { iIconsConfig, iTerms } from '../base/lovelace-base';\nimport {\n  getEntityIcon,\n  getEntityNumericValue,\n  getEntityRawAttribute,\n  getEntityRawValue,\n  getEntityUnit,\n  getLocaleInfo,\n  getWindDirections,\n} from '../utils/helper';\nimport { iconPrecipitation, iconTemperature } from '../utils/const';\nimport { iForecastDataItem, renderWeatherForecast } from '../templates/t-weather-forecast';\nimport {\n  iDailyForecast,\n  iHourlyForecast,\n  iMarineDailyForecast,\n  iMarineHourlyForecast,\n} from '../utils/config-schema';\n\nconst getDefaultIcon = (metric: string): string => {\n  if (metric.includes('temperature')) return iconTemperature;\n  if (metric.includes('precipitation')) return iconPrecipitation;\n  return 'mdi:help-circle-outline';\n};\n\nconst buildHourlyForecastSlot = (\n  hass: HomeAssistant,\n  lang: string,\n  cwcLocWindDirections,\n  forecast: iHourlyForecast,\n  forecastType: number,\n  iconsConfig: iIconsConfig,\n  sunState: string,\n  slotId: string,\n) => {\n  const record: Record<string, iForecastDataItem> = {};\n  const localeInfo = getLocaleInfo(lang);\n\n  let datetime: Date;\n\n  // Condizione meteo\n  if (forecast.condition && forecast.condition[slotId]) {\n    record['condition'] = {\n      img: getWeatherIcon(getEntityRawValue(hass, forecast.condition[slotId]), iconsConfig, sunState),\n    };\n  }\n\n  // Wind Bearing\n  if (forecast.wind_bearing && forecast.wind_bearing[slotId]) {\n    record['wind_bearing'] = {\n      value: getWindDirections(getEntityRawValue(hass, forecast.wind_bearing[slotId]), cwcLocWindDirections),\n    };\n  }\n   \n  // Metriche da gestire\n  const metrics = [\n    'temperature',\n    'temperature_feelslike',\n    'precipitation_intensity',\n    'precipitation_probability',\n    'wind_speed',\n  ];\n\n  metrics.forEach((metricKey) => {\n    const metricSlots = forecast[metricKey];\n    const entityId = metricSlots?.[slotId];\n    let decimals = 0;\n\n    if (!entityId) return;\n\n    if (metricKey === 'precipitation_intensity') decimals = 2;\n\n    datetime = new Date(getEntityRawAttribute(hass, entityId, 'datetime'));\n\n    record[metricKey] = {\n      value: getEntityNumericValue({\n        entityId, hass, lang, decimals,\n      }),\n      unit: getEntityUnit(hass, entityId),\n      img: getEntityIcon(hass, entityId) || getDefaultIcon(metricKey),\n    };\n  });\n\n  if (datetime && Object.keys(record).length > 0) {\n    const hourTime = datetime.toLocaleTimeString(localeInfo.locale, {\n      hour: '2-digit',\n      minute: '2-digit',\n      timeZone: localeInfo.timezone,\n    });\n\n    record['reference'] = {\n      value: (forecastType === 0 ? hourTime : hourTime),\n    };\n  }\n\n  return record;\n};\n\nconst buildDailyForecastSlot = (\n  hass: HomeAssistant,\n  lang: string,\n  forecast: iDailyForecast,\n  forecastType: number,\n  iconsConfig: iIconsConfig,\n  sunState: string,\n  slotId: string,\n) => {\n  const record: Record<string, iForecastDataItem> = {};\n  const localeInfo = getLocaleInfo(lang);\n\n  let datetime: Date;\n\n  // Gestione condizione meteo\n  if (forecast.condition && forecast.condition[slotId]) {\n    record['condition'] = {\n      img: getWeatherIcon(getEntityRawValue(hass, forecast.condition[slotId]), iconsConfig, sunState),\n    };\n  }\n\n  // Lista fissa delle metriche da considerare\n  const metrics = [\n    'temperature_high',\n    'temperature_low',\n    'precipitation_intensity',\n    'precipitation_probability',\n  ];\n\n  metrics.forEach((metricKey) => {\n    const metricSlots = forecast[metricKey];\n    const entityId = metricSlots?.[slotId];\n    let decimals = 0;\n\n    if (!entityId) return;\n\n    if (metricKey === 'precipitation_intensity') {\n      decimals = 2;\n    }\n\n    datetime = new Date(getEntityRawAttribute(hass, entityId, 'datetime'));\n    // console.debug(`>>> ${entityId} ${lang} ${getEntityNumericValue({ entityId, hass, lang })}`);\n    record[metricKey] = {\n      value: getEntityNumericValue({\n        entityId, hass, lang, decimals,\n      }),\n      unit: getEntityUnit(hass, entityId),\n      img: getEntityIcon(hass, entityId) || getDefaultIcon(metricKey),\n    };\n  });\n\n  if (datetime && Object.keys(record).length > 0) {\n    // Giorno della settimana abbreviato (es. \"Lun\")\n    const weekday = datetime.toLocaleDateString(localeInfo.locale, {\n      weekday: 'short',\n      timeZone: 'UTC', // forza la lettura senza conversione locale\n    });\n\n    // Ora e minuti (es. \"13:45\")\n    const hourday = datetime.toLocaleTimeString(localeInfo.locale, {\n      hour: '2-digit',\n      minute: '2-digit',\n      timeZone: localeInfo.timezone,\n    });\n\n    record['reference'] = {\n      value: (forecastType === 0 ? weekday.toUpperCase() : hourday),\n    };\n  }\n\n  return record;\n};\n\nconst buildMarineDailyForecastSlot = (\n  hass: HomeAssistant,\n  lang: string,\n  cwcLocWindDirections,\n  forecast: iMarineDailyForecast,\n  forecastType: number,\n  iconsConfig: iIconsConfig,\n  sunState: string,\n  slotId: string,\n) => {\n  const record: Record<string, iForecastDataItem> = {};\n\n  const fieldColor = (\n    waveHeightMax: number,\n    swellWaveHeightMax: number,\n    windWaveHeightMax: number,\n  ) => {\n    // 🟥 Bandiera rossa – condizioni pericolose\n    if (waveHeightMax >= 1.8) {\n      return 'red';\n    }\n\n    if (swellWaveHeightMax >= 1.5 && windWaveHeightMax >= 0.8) {\n      return 'red';\n    }\n\n    // 🟨 Bandiera gialla – condizioni da attenzionare\n    if (waveHeightMax >= 1.0) {\n      return 'yellow';\n    }\n\n    if (swellWaveHeightMax >= 0.8) {\n      return 'yellow';\n    }\n\n    if (windWaveHeightMax >= 0.6) {\n      return 'yellow';\n    }\n\n    // 🟩 Bandiera verde – condizioni sicure\n    return 'green';\n  };\n\n  const localeInfo = getLocaleInfo(lang);\n\n  let datetime: Date;\n\n  // Gestione condizione meteo\n  if (\n    forecast.wave_height_max &&\n    forecast.swell_wave_height_max &&\n    forecast.wind_wave_height_max &&\n    forecast.swell_wave_height_max[slotId] &&\n    forecast.wind_wave_height_max[slotId]\n  ) {\n    record['condition'] = {\n      icon: 'mdi:flag-variant',\n      iconColor: fieldColor(forecast.wave_height_max[slotId], forecast.swell_wave_height_max[slotId], forecast.wind_wave_height_max[slotId]),\n    };\n  }\n\n  // Wind Bearing\n  if (forecast.wave_direction && forecast.wave_direction[slotId]) {\n    record['wave_direction'] = {\n      value: getWindDirections(getEntityRawValue(hass, forecast.wave_direction[slotId]), cwcLocWindDirections),\n      icon: getEntityRawValue(hass, forecast.wave_direction[slotId]),\n    };\n  }\n\n  // Lista fissa delle metriche da considerare\n  const metrics = [\n    'wave_height_max',\n    'swell_wave_height_max',\n    'wind_wave_height_max',\n  ];\n\n  metrics.forEach((metricKey) => {\n    const metricSlots = forecast[metricKey];\n    const entityId = metricSlots?.[slotId];\n    const decimals = 1;\n\n    if (!entityId) return;\n\n    datetime = new Date(getEntityRawAttribute(hass, entityId, 'datetime'));\n    // console.debug(`>>> ${entityId} ${lang} ${getEntityNumericValue({ entityId, hass, lang })}`);\n    record[metricKey] = {\n      value: getEntityNumericValue({\n        entityId, hass, lang, decimals,\n      }),\n      unit: getEntityUnit(hass, entityId),\n      img: getEntityIcon(hass, entityId) || getDefaultIcon(metricKey),\n    };\n  });\n\n  if (datetime && Object.keys(record).length > 0) {\n    // Giorno della settimana abbreviato (es. \"Lun\")\n    const weekday = datetime.toLocaleDateString(localeInfo.locale, {\n      weekday: 'short',\n      timeZone: 'UTC', // forza la lettura senza conversione locale\n    });\n\n    // Ora e minuti (es. \"13:45\")\n    const hourday = datetime.toLocaleTimeString(localeInfo.locale, {\n      hour: '2-digit',\n      minute: '2-digit',\n      timeZone: localeInfo.timezone,\n    });\n\n    record['reference'] = {\n      value: (forecastType === 2 ? weekday.toUpperCase() : hourday),\n    };\n  }\n\n  return record;\n};\n\nconst buildWeatherForecast = (\n  hass: HomeAssistant,\n  lang: string,\n  terms: iTerms,\n  dailyForecast: iDailyForecast,\n  hourlyForecast: iHourlyForecast,\n  marineDailyForecasts: iMarineDailyForecast,\n  marineHourlyForecasts: iMarineHourlyForecast,\n  forecastType: (0 | 1 | 2 | 3),\n  iconsConfig: iIconsConfig,\n  sunEntityId: string,\n) => {\n  const voidRecord: Record<string, iForecastDataItem>[] = [];\n  \n  const sunState = getEntityRawValue(hass, sunEntityId);\n\n  let dailyForecastData = voidRecord;\n  if (dailyForecast) {\n    const dailySlotIds = Object.keys(\n      dailyForecast.condition ||\n      dailyForecast.temperature_high || dailyForecast.temperature_low ||\n      dailyForecast.precipitation_intensity || dailyForecast.precipitation_probability ||\n      {},\n    );\n    dailyForecastData = dailySlotIds.map((slotId) => buildDailyForecastSlot(\n      hass,\n      lang,\n      dailyForecast,\n      forecastType,\n      iconsConfig,\n      sunState,\n      slotId,\n    ));\n  }\n\n  let hourlyforecastData = voidRecord;\n  if (hourlyForecast) {\n    const hourlySlotIds = Object.keys(\n      hourlyForecast.condition ||\n      hourlyForecast.temperature || hourlyForecast.temperature_feelslike ||\n      hourlyForecast.precipitation_intensity || hourlyForecast.precipitation_probability ||\n      {},\n    );\n    hourlyforecastData = hourlySlotIds.map((slotId) => buildHourlyForecastSlot(\n      hass,\n      lang,\n      terms.windDirections,\n      hourlyForecast,\n      forecastType,\n      iconsConfig,\n      sunState,\n      slotId,\n    ));\n  }\n\n  let marineDailyForecastData = voidRecord;\n  if (marineDailyForecasts) {\n    const marineDailySlotIds = Object.keys(\n      marineDailyForecasts.swell_wave_height_max ||\n      marineDailyForecasts.wave_direction || marineDailyForecasts.wave_height_max ||\n      marineDailyForecasts.wind_wave_height_max ||\n      {},\n    );\n    marineDailyForecastData = marineDailySlotIds.map((slotId) => buildMarineDailyForecastSlot(\n      hass,\n      lang,\n      terms.windDirections,\n      marineDailyForecasts,\n      forecastType,\n      iconsConfig,\n      sunState,\n      slotId,\n    ));\n  }\n\n  switch (forecastType) {\n    case 0:\n      return renderWeatherForecast(forecastType, dailyForecastData);\n    case 1:\n      return renderWeatherForecast(forecastType, hourlyforecastData);\n    case 2:\n      return renderWeatherForecast(forecastType, marineDailyForecastData);\n    default:\n      return renderWeatherForecast(forecastType, voidRecord);\n  }\n};\n\nexport default buildWeatherForecast;\n"
  },
  {
    "path": "src/css/css-base-card.ts",
    "content": "import { css } from 'lit';\n\nconst cardStyle = css`\n  ha-card {\n    cursor: pointer;\n    position: relative;\n    width: 100%;\n  }\n\n  .ha-card-weather-conditions {\n    width: 100%;\n    box-sizing: border-box;\n    background-color: var(--card-background-color, #1c1c1c);\n    color: var(--primary-text-color, #ffffff);\n    border-radius: var(--ha-card-border-radius, 12px);\n    box-shadow: var(--ha-card-box-shadow, 0 2px 6px rgba(0, 0, 0, 0.2));\n    overflow: hidden;\n    padding: 0;\n    display: flex;\n    flex-direction: column;\n  }\n\n  .nd-container {\n    width: 100%;\n    box-sizing: border-box;\n    display: flex;\n    flex-direction: column;\n    padding: 16px 20px; /* ← padding orizzontale più ampio */\n    gap: 12px;\n    background-size: cover;\n    background-position: center;\n    transition: background-image 0.3s ease-in-out;\n  }\n\n  /* Esempio di stile dinamico aggiuntivo se habgImage è una classe */\n  .nd-container.sunny {\n    background-image: url('/local/images/sunny-bg.jpg');\n  }\n\n  .nd-container.rainy {\n    background-image: url('/local/images/rainy-bg.jpg');\n  }\n\n  /* -------------- */\n\n`;\n\nexport default cardStyle;\n"
  },
  {
    "path": "src/css/css-camera.ts",
    "content": "import { css } from 'lit';\n\nconst cameraStyle = css`\n  .camera-container {\n    margin-top: 10px;\n    width: 100%;\n    display: flex;\n    align-items: stretch;\n  }\n\n  .camera-image {\n    aspect-ratio: 16 / 9;\n    width: 100%;\n    position: relative;\n    overflow: hidden;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n  }\n\n  .camera-image > img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n  }\n`;\n\nexport default cameraStyle;\n"
  },
  {
    "path": "src/css/css-meteoalarm.ts",
    "content": "import { css } from 'lit';\n\nconst meteodcpalarmStyle = css`\n.meteodcpalarm-grid-container {\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: center;\n  gap: 16px;\n  padding: 12px;\n}\n\n.meteodcpalarm-group {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  flex: 1 1 72px;     /* 👈 cresce, ma non scende sotto i 72px */\n  max-width: 220px;   /* 👈 opzionale: previene allargamento eccessivo */\n  text-align: center;\n}\n\n.meteodcpalarm-group ha-icon {\n  --mdc-icon-size: 36px;\n}\n\n.meteodcpalarm-label {\n  margin-top: 6px;\n  font-size: 0.85em;\n  color: var(--primary-text-color);\n}\n\n\n`;\n\nexport default meteodcpalarmStyle;\n"
  },
  {
    "path": "src/css/css-pollen.ts",
    "content": "import { css } from 'lit';\n\nconst pollenStyle = css`\n.pollen-grid-container {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(48px, 1fr));\n  gap: 8px 12px;\n  width: 100%;\n  justify-items: center;\n  align-items: end;\n  padding: 8px 4px;\n  box-sizing: border-box;\n}\n\n\n.pollen-stack {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  gap: 4px;\n  min-width: 48px;\n}\n\n\n  .levels {\n    display: flex;\n    flex-direction: column-reverse;\n    gap: clamp(1px, 0.2vw, 2px);\n  }\n\n  .level {\n    width: clamp(16px, 3.5vw, 24px);\n    height: clamp(5px, 0.7vw, 8px);     /* 👈 anche in altezza */\n    border-radius: 3px;\n    opacity: 0.3;\n    transition: opacity 0.2s ease;\n  }\n\n  .level.active {\n    opacity: 1;\n    outline: 1px solid #333;\n  }\n\n  .molto-alto {\n    background-color: #f44336;\n  }\n\n  .alto {\n    background-color: #ff9800;\n  }\n\n  .moderato {\n    background-color: #ffeb3b;\n  }\n\n  .basso {\n    background-color: #4caf50;\n  }\n\n  .pollen-name {\n    font-size: clamp(0.55em, 1.3vw, 0.85em); /* 👈 stringe di più */\n    // font-weight: 500;\n    text-align: center;\n    // color: #333;\n    white-space: nowrap;\n  }\n\n  .label {\n    width: 100%;\n    text-align: center;\n    font-size: clamp(0.55em, 1.3vw, 0.85em);\n    // font-weight: 500;\n    margin-top: clamp(4px, 0.5vw, 8px);\n  }\n`;\n\nexport default pollenStyle;\n"
  },
  {
    "path": "src/css/css-present.ts",
    "content": "import { css } from 'lit';\n\nconst presentStyle = css`\n.present-grid-container {\n  display: flex;\n  flex-direction: column;\n  gap: 4px;\n}\n\n.present-row {\n  display: flex;\n  justify-content: space-between;\n  gap: 16px;\n}\n\n.present-left,\n.present-right {\n  flex: 1;\n}\n\n.present-left {\n  display: flex;\n  justify-content: flex-start;\n}\n\n.present-right {\n  display: flex;\n  justify-content: flex-end;\n}\n\n.present-value-block {\n  display: flex;\n  align-items: center;\n  gap: 4px;\n}\n\n.present-unit {\n  font-size: 0.9em;\n  opacity: 0.8;\n}\n`;\n\nexport default presentStyle;\n"
  },
  {
    "path": "src/css/css-summary.ts",
    "content": "import { css } from 'lit';\n\nconst summaryStyle = css`\n\n.summary-grid-container {\n  position: relative;\n  z-index: 1;\n  display: grid;\n  grid-template-columns: 1fr 1fr 1fr; /* <-- 3 colonne reali */\n  grid-template-rows: auto auto;\n  width: 100%;\n  max-width: 600px;\n  // background: #1c1c1c;\n  // color: white;\n  gap: 4px;\n  padding: 0px;\n  box-sizing: border-box;\n  // border: 1px solid #444; /* debug */\n}\n\n.summary-col-left {\n  grid-column: 1;\n  grid-row: 1 / span 2;\n  // background: #2c2c2c;\n  padding-top: 0px;\n  padding-right: 0px;\n  padding-bottom: 0px;\n  padding-left: 0px;\n  \n  display: flex;                 /* Attiva Flexbox */\n  justify-content: center;      /* Centra orizzontalmente */\n  align-items: center;          /* Centra verticalmente */\n\n  width: 100%;\n  max-width: 100%;\n  aspect-ratio: 1 / 1; /* opzionale: mantiene forma quadrata */\n  overflow: hidden;\n}\n\n.summary-top-right {\n  grid-column: 2 / span 2; /* occupa colonne 2 e 3 */\n  grid-row: 1;\n  // background: #3c3c3c;\n  padding-top: 0px;\n  padding-right: 8px;\n  padding-bottom: 0px;\n  padding-left: 8px;\n  display: flex;            /* aggiunto */\n  align-items: center;      /* centra verticalmente */\n  justify-content: flex-start; /* allinea a sinistra */\n}\n\n.summary-bottom-right-left {\n  grid-column: 2;\n  grid-row: 2;\n  // background: #4c4c4c;\n  padding-top: 0px;\n  padding-right: 8px;\n  padding-bottom: 0px;\n  padding-left: 8px;\n\n  display: flex;                 /* Attiva Flexbox */\n  justify-content: center;      /* Centra orizzontalmente */\n  align-items: center;          /* Centra verticalmente */\n}\n\n.summary-bottom-right-right {\n  grid-column: 3;\n  grid-row: 2;\n  // background: #5c5c5c;\n  padding-top: 0px;\n  padding-right: 8px;\n  padding-bottom: 0px;\n  padding-left: 8px;\n}\n\n.weather-condition-icon {\n  width: 100%;\n  height: auto;\n  max-width: 100%;\n  max-height: 100%;\n  object-fit: contain;\n  // max-width: 100%;\n  // max-height: 100%;\n  // width: 72px;\n  // height: 72px;\n  // object-fit: contain;\n\n  transition: transform 0.2s ease;\n}\n  \n.summary-col-left:hover .weather-condition-icon {\n  transform: scale(1.05);\n}\n\n.weather-city-name {\n  font-size: clamp(1em, 2vw, 1.2em);\n  text-align: left;\n}\n\n.moon-row {\n  display: flex;\n  align-items: center;\n  gap: 6px;\n  // font-size: 0.95em;\n  // color: #eeeeee;\n}\n\n.summary-moon-icon {\n  font-size: 1.8em;\n  display: inline-block;\n}\n\n.temperature-block {\n  display: flex;\n  flex-direction: column;\n  align-items: flex-end;\n  text-align: right;\n}\n\n.temperature {\n  font-size: 1.6em;\n  font-weight: bold;\n}\n\n.temp-unit {\n  font-size: 0.95em;\n  vertical-align: super;\n  margin-left: 2px;\n}\n\n.feels-like {\n  font-size: 0.85em;\n  // color: #aaaaaa;\n}\n\n.summary-wrapper {\n  position: relative;\n  width: 100%;\n  height: 100%;\n  min-height: 100px; /* oppure clamp() dinamico */\n  overflow: visible;\n}\n\n.lightning-background {\n  position: absolute;\n  inset: 0; /* top: 0; right: 0; bottom: 0; left: 0 */\n  pointer-events: none;\n  z-index: 0;\n}\n\n.lightning-flash {\n  position: absolute;\n  width: 2px;\n  background: white;\n  opacity: 0.7;\n  transform: translate(-50%, -50%);\n  animation-name: flash-blink;\n  animation-timing-function: ease-in-out;\n  animation-iteration-count: infinite;\n  border-radius: 1px;\n  filter: blur(0.5px);\n  box-shadow: 0 0 4px rgba(255,255,255,0.6);\n\n  z-index: 0;\n}\n\n@keyframes flash-blink {\n  0%, 100% {\n    opacity: 0.1;\n  }\n  50% {\n    opacity: 0.9;\n  }\n}\n\n.lightning-flash-zigzag {\n  position: absolute;\n  width: 2px;\n  height: 0;\n  background: linear-gradient(to bottom, yellow, white);\n  clip-path: polygon(var(--points));\n  animation: flash-zigzag linear forwards;\n  z-index: 3;\n}\n\n@keyframes flash-zigzag {\n  0% {\n    opacity: 1;\n    transform: scaleY(1);\n  }\n  100% {\n    opacity: 0;\n    transform: scaleY(1.2);\n  }\n}\n\n.lightning-svg {\n  position: absolute;\n  transform: translate(-50%, 0);\n  opacity: 0;\n  filter: drop-shadow(0 0 4px rgba(98, 61, 173, 0.6));\n  animation-name: flash-zigzag-svg;\n  animation-timing-function: ease-in-out;\n  animation-iteration-count: 1;\n  z-index: 3;\n}\n\n@keyframes flash-zigzag-svg {\n  0%, 100% {\n    opacity: 0;\n  }\n  40% {\n    opacity: 1;\n  }\n  60% {\n    opacity: 0.5;\n  }\n}\n`;\n\nexport default summaryStyle;\n"
  },
  {
    "path": "src/css/css-ultraviolet.ts",
    "content": "import { css } from 'lit';\n\nconst ultravioletStyle = css`\n.ultraviolet-grid-container {\n  display: flex;\n  flex-direction: column;\n  gap: 4px;\n}\n\n.ultraviolet-row {\n  display: flex;\n  justify-content: space-between;\n  gap: 16px;\n}\n\n.ultraviolet-left,\n.present-right {\n  flex: 1;\n}\n\n.ultraviolet-left {\n  display: flex;\n  justify-content: flex-start;\n}\n\n.ultraviolet-right {\n  display: flex;\n  justify-content: flex-end;\n}\n\n.ultraviolet-value-block {\n  display: flex;\n  align-items: center;\n  gap: 4px;\n}\n\n.ultraviolet-unit {\n  font-size: 0.9em;\n  opacity: 0.8;\n}\n\n------------------------------------------------------------------\n\n// .ultraviolet-grid-container {\n//   display: flex;\n//   flex-direction: column;\n//   gap: 12px;\n// }\n\n// .ultraviolet-row {\n//   display: flex;\n//   justify-content: space-between;\n//   padding: 4px 0;\n// }\n\n// .ultraviolet-value-block {\n//   display: flex;\n//   align-items: center;\n//   gap: 4px;\n// }\n\n// .ultraviolet-unit {\n//   font-size: 0.9em;\n//   opacity: 0.7;\n// }\n\n.ultraviolet-skin-type-grid {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(48px, 1fr));\n  gap: 8px;\n  margin-top: 8px;\n}\n\n.ultraviolet-skin-type-cell {\n  flex: 1;\n  min-width: 48px;\n  height: 48px;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  border-radius: 6px;\n  font-family: 'Segoe UI', sans-serif;\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);\n  color: black;\n}\n\n.ultraviolet-skin-type-label {\n  font-weight: bold;\n  font-size: 0.95em;\n  line-height: 1em;\n}\n\n.ultraviolet-exposure-time {\n  font-size: 0.75em;\n  margin-top: 2px;\n  color: #222;\n  opacity: 0.85;\n}\n\n\n\n\n\n\n`;\n\nexport default ultravioletStyle;\n"
  },
  {
    "path": "src/css/css-weather-forecast.ts",
    "content": "import { css } from 'lit';\n\nconst weatherForecastStyle = css`\n\n.weather-forecast-grid-container {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(78px, 1fr));\n  column-gap: 2px; /* spazio orizzontale tra i giorni */\n  row-gap: 6px;    /* spazio verticale tra righe, se ci sono */\n  align-items: stretch;\n  font-family: 'Segoe UI', sans-serif;\n  width: 100%;\n}\n  \n.weather-forecast-grid-wrapper {\n  display: flex;\n  flex-direction: column;\n  align-items: center; /* centrare il titolo orizzontalmente */\n}\n\n.weather-forecast-title {\n  font-size: clamp(0.85em, 1vw, 0.95em);\n  font-weight: bold;\n  // margin-bottom: 0.5em;\n  text-align: center;\n}\n\n.weather-forecast-slot {\n  text-align: center;\n  padding: 8px 4px;\n  min-width: 0;\n  overflow: hidden;\n}\n\n.weather-forecast-slot:last-child {\n  border-right: none;\n}\n\n.weather-forecast-label-slot {\n  font-size: 0.9em;\n  font-weight: bold;\n  margin-bottom: 6px; /* ridotto */\n}\n\n.weather-forecast-icon {\n  font-size: 1.6rem; /* ridotto */\n  /* margin: 6px 0; ridotto */\n  height: 32px;\n}\n\n.weather-forecast-temperature {\n  font-size: clamp(0.8em, 1vw, 0.9em); /* leggermente più piccolo */\n  margin: 4px 0; /* meno margine */\n}\n\n.weather-forecast-temperature .high {\n  font-weight: bold;\n}\n\n.weather-forecast-precipitation {\n  font-size: clamp(0.65em, 1vw, 0.75em);\n  line-height: 1.2; /* compatta verticalmente */\n}\n\n.weather-forecast-precipitation .mm {\n  font-weight: bold;\n}\n`;\n\nexport default weatherForecastStyle;\n"
  },
  {
    "path": "src/ha-weather-ecard.ts",
    "content": "/* eslint-disable no-underscore-dangle */\nimport { html, TemplateResult } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { LovelaceBaseElement, preloadResources } from './base/lovelace-base';\n\nimport buildWeatherSummary from './builder/b-summary';\nimport buildWeatherPresent from './builder/b-present';\nimport buildUltraviolet from './builder/b-ultraviolet';\nimport buildPollen from './builder/b-pollen';\nimport buildWeatherForecast from './builder/b-weather-forecast';\nimport buildCamera from './builder/b-camera';\nimport buildAirQuality from './builder/b-airquality';\nimport buildMeteoDPCalarm from './builder/b-meteoalarm';\n\nconst { translations, imagePath } = await preloadResources(); // esecuzione immediata\n\n/* -------------------- DEFINIZIONE COMPONENTE -------------------- */\n\n@customElement('ha-card-weather-conditions')\n// eslint-disable-next-line import/prefer-default-export\nexport class HaCardWeatherConditions extends LovelaceBaseElement {\n  _translations = translations;\n\n  _imagesPath = imagePath;\n\n  // eslint-disable-next-line class-methods-use-this\n  protected _render(): TemplateResult {\n    return html`\n      <ha-card class=\"ha-card-weather-conditions\">\n        <div class=\"nd-container\">\n          ${this._buildTemplate()}\n        </div>\n      </ha-card>\n    `;\n  }\n\n  private _buildTemplate(): TemplateResult {\n    let summary = html``;\n    let present = html``;\n    let dailyWeatherForecast = html``;\n    let hourlyWeatherForecast = html``;\n    let marineDailyWeatherForecast = html``;\n    let marineHourlyWeatherForecast = html``;\n    let meteoDPCalarm = html``;\n    let ultraviolet = html``;\n    let pollen = html``;\n    let airQuality = html``;\n    let camera = html``;\n\n    const getWeatherForecast = (mode: 0 | 1 | 2 | 3) => buildWeatherForecast(\n      this.hass,\n      this._language,\n      this._terms,\n      this._config.weather.daily_forecasts,\n      this._config.weather.hourly_forecasts,\n      this._config.weather.marine_daily_forecasts,\n      this._config.weather.marine_hourly_forecasts,\n      mode,\n      this._iconsConfig,\n      this._config.weather.sun,\n    );\n\n    if (this._hasPresent) {\n      summary = buildWeatherSummary(\n        this.hass,\n        this._language,\n        this._terms,\n        this._iconsConfig,\n        this._config.weather?.name,\n        this._config?.weather?.present || null,\n        this._config?.weather?.sun,\n        this._config?.weather?.moonphase,\n      );\n    }\n\n    if (this._hasPresent) {\n      present = buildWeatherPresent(\n        this.hass,\n        this._language,\n        this._terms,\n        this._config?.weather?.present || {},\n        this._config?.weather?.sun,\n      );\n    }\n\n    if (this._hasMetealarm || this._hasDPCalarm) {\n      meteoDPCalarm = buildMeteoDPCalarm(\n        this.hass,\n        this._language,\n        this._terms,\n        this._config?.weather?.meteoalarm,\n        this._config?.weather?.dpcalarm,\n      );\n    }\n\n    if (this._hasDailyForecasts) {\n      dailyWeatherForecast = getWeatherForecast(0);\n    }\n    if (this._hasHourlyForecasts) {\n      hourlyWeatherForecast = getWeatherForecast(1);\n    }\n    if (this._hasMarineDailyForecasts) {\n      marineDailyWeatherForecast = getWeatherForecast(2);\n    }\n    if (this._hasMarineHourlyForecasts) {\n      marineHourlyWeatherForecast = getWeatherForecast(3);\n    }\n\n    if (this._hasUltraviolet) {\n      ultraviolet = buildUltraviolet(this.hass, this._language, this._config.ultraviolet);\n    }\n\n    if (this._hasPollen) {\n      pollen = buildPollen(this.hass, this._language, this._config.pollen);\n    }\n\n    if (this._hasAirQuality) {\n      airQuality = buildAirQuality(this.hass, this._language, this._config.airquality);\n    }\n\n    if (this._hasCamera) {\n      camera = buildCamera(this.hass, this._language, this._terms, this._handlePopup.bind(this), this._config.camera);\n    }\n\n    return html`\n    ${summary}\n    ${present}\n    ${hourlyWeatherForecast}\n    ${dailyWeatherForecast}\n    ${marineHourlyWeatherForecast}\n    ${marineDailyWeatherForecast}\n    ${meteoDPCalarm}\n    ${pollen}\n    ${ultraviolet}\n    ${airQuality}\n    ${camera}`;\n  }\n\n  /**\n   * Apre il popup di dettaglio per l'entità specificata.\n   * @param e L'evento click originale.\n   * @param entityId L'ID dell'entità Home Assistant da mostrare.\n   */\n  protected _handlePopup(e: Event, entityId: string) {\n    e.stopPropagation();\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const moreInfoEvent = new Event('hass-more-info', { composed: true }) as any;\n    moreInfoEvent.detail = { entityId };\n    this.dispatchEvent(moreInfoEvent);\n  }\n}\n"
  },
  {
    "path": "src/iconmodels/im-buienradar.ts",
    "content": "// clear=ok, partlycloudy=ok, cloudy=ok, partlycloudy-fog=ok, partlycloudy-light-rain=ok, partlycloudy-rain=ok,\n// light-rain=ok, rainy=ok, snowy-rainy=ok, partlycloudy-light-snow=ok, partlycloudy-snow=ok, light-snow=ok, snowy=ok,\n// partlycloudy-lightning=ok or lightning\n\nexport const cwcBuienradarDayIcons: { [key: string]: string; } = {\n  // freezing_rain_heavy: 'rainy-3',\n  // freezing_rain: 'rainy-2',\n  // freezing_rain_light: 'rainy-1',\n  // freezing_drizzle: 'rain-and-sleet-mix',\n  // ice_pellets_heavy: 'rain-and-snow-mix',\n  // ice_pellets: 'rain-and-snow-mix',\n  // ice_pellets_light: 'rain-and-snow-mix',\n  snowy: 'snowy-3',\n  'light-snow': 'snowy-2',\n  'snowy-rainy': 'snowy-1',\n  'partlycloudy-light-snow': 'snowy-1',\n  'partlycloudy-snow': 'snowy-1',\n  // flurries: 'wind',\n  // tstorm: 'tropical-storm',\n  // rain_heavy: 'rainy-3',\n  'partlycloudy-light-rain': 'rainy-1',\n  'light-rain': 'rainy-1',\n  rainy: 'rainy-2',\n  'partlycloudy-rain': 'rainy-1',\n  // fog_light: 'haze',\n  'partlycloudy-fog': 'fog',\n  cloudy: 'cloudy-original',\n  // mostly_cloudy: 'cloudy-day-3',\n  partlycloudy: 'cloudy-day-2',\n  'partlycloudy-lightning': 'cloudy-day-1',\n  lightning: 'cloudy-day-1',\n  // mostly_clear: 'cloudy-day-1',\n  clear: 'day',\n};\n\nexport const cwcBuienradarNightIcons: { [key: string]: string; } = {\n  ...cwcBuienradarDayIcons,\n  // freezing_rain_heavy: 'rainy-6',\n  // freezing_rain: 'rainy-5',\n  // freezing_rain_light: 'rainy-4',\n  // freezing_drizzle: 'rain-and-sleet-mix',\n  // ice_pellets_heavy: 'rain-and-snow-mix',\n  // ice_pellets: 'rain-and-snow-mix',\n  // ice_pellets_light: 'rain-and-snow-mix',\n  // snow_heavy: 'snowy-6',\n  // snow: 'nowy-5',\n  // snow_light: 'nowy-4',\n  // flurries: 'wind',\n  // tstorm: 'tropical-storm',\n  // rain_heavy: 'rainy-6',\n  // rain_light: 'rainy-4',\n  // rain: 'rainy-5',\n  // drizzle: 'rainy-4',\n  // fog_light: 'haze',\n  // fog: 'fog',\n  // cloudy: 'cloudy',\n  // mostly_cloudy: 'cloudy-night-3',\n  // partly_cloudy: 'cloudy-night-2',\n  // mostly_clear: 'cloudy-night-1',\n  // clear: 'night'\n};\n"
  },
  {
    "path": "src/iconmodels/im-climacell.ts",
    "content": "export const cwcClimacellDayIcons: { [key: string]: string; } = {\n  freezing_rain_heavy: 'rainy-3',\n  'heavy freezing rain': 'rainy-3',\n  freezing_rain: 'rainy-2',\n  'freezing rain': 'rainy-2',\n  freezing_rain_light: 'rainy-1',\n  'light freezing rain': 'rainy-1',\n  freezing_drizzle: 'rain-and-sleet-mix',\n  'freezing drizzle': 'rain-and-sleet-mix',\n  ice_pellets_heavy: 'rain-and-snow-mix',\n  'heavy ice pellets': 'rain-and-snow-mix',\n  ice_pellets: 'rain-and-snow-mix',\n  'ice pellets': 'rain-and-snow-mix',\n  ice_pellets_light: 'rain-and-snow-mix',\n  'light ice pellets': 'rain-and-snow-mix',\n  snow_heavy: 'snowy-3',\n  'heavy snow': 'snowy-3',\n  snow: 'snowy-2',\n  snow_light: 'snowy-1',\n  'light snow': 'snowy-1',\n  flurries: 'wind',\n  tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-3',\n  'heavy rain': 'rainy-3',\n  rain_light: 'rainy-1',\n  'light rain': 'rainy-1',\n  rain: 'rainy-2',\n  drizzle: 'rainy-1',\n  fog_light: 'haze',\n  'light fog': 'haze',\n  fog: 'fog',\n  cloudy: 'cloudy-original',\n  mostly_cloudy: 'cloudy-day-3',\n  'mostly cloudy': 'cloudy-day-3',\n  partly_cloudy: 'cloudy-day-2',\n  'partly cloudy': 'cloudy-day-2',\n  mostly_clear: 'cloudy-day-1',\n  'mostly clear': 'cloudy-day-1',\n  clear: 'day',\n};\n\nexport const cwcClimacellNightIcons: { [key: string]: string; } = {\n  ...cwcClimacellDayIcons,\n  freezing_rain_heavy: 'rainy-6',\n  'heavy freezing rain': 'rainy-6',\n  freezing_rain: 'rainy-5',\n  'freezing rain': 'rainy-5',\n  freezing_rain_light: 'rainy-4',\n  'light freezing rain': 'rainy-4',\n  // freezing_drizzle: 'rain-and-sleet-mix',\n  // ice_pellets_heavy: 'rain-and-snow-mix',\n  // ice_pellets: 'rain-and-snow-mix',\n  // ice_pellets_light: 'rain-and-snow-mix',\n  snow_heavy: 'snowy-6',\n  'heavy snow': 'snowy-6',\n  snow: 'snowy-5',\n  snow_light: 'snowy-4',\n  'light snow': 'snowy-4',\n  // flurries: 'wind',\n  // tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-6',\n  'heavy rain': 'rainy-6',\n  rain_light: 'rainy-4',\n  'light rain': 'rainy-4',\n  rain: 'rainy-5',\n  drizzle: 'rainy-4',\n  // fog_light: 'haze',\n  // fog: 'fog',\n  // cloudy: 'cloudy',\n  mostly_cloudy: 'cloudy-night-3',\n  'mostly cloudy': 'cloudy-night-3',\n  partly_cloudy: 'cloudy-night-2',\n  'partly cloudy': 'cloudy-night-2',\n  mostly_clear: 'cloudy-night-1',\n  'mostly clear': 'cloudy-night-1',\n  clear: 'night',\n  sunny: 'night',\n};\n\nexport const cwcClimacellDayBg: { [key: string]: string; } = {\n  freezing_rain_heavy: 'rainy-3',\n  freezing_rain: 'rainy-2',\n  freezing_rain_light: 'rainy-1',\n  freezing_drizzle: 'rain-and-sleet-mix',\n  ice_pellets_heavy: 'rain-and-snow-mix',\n  ice_pellets: 'rain-and-snow-mix',\n  ice_pellets_light: 'rain-and-snow-mix',\n  snow_heavy: 'snowy-3',\n  snow: 'snowy-2',\n  snow_light: 'snowy-1',\n  flurries: 'wind',\n  tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-3',\n  rain_light: 'rainy-1',\n  rain: 'rainy-2',\n  drizzle: 'rainy-1',\n  fog_light: 'haze',\n  fog: 'fog',\n  cloudy: 'cloudy-original',\n  mostly_cloudy: 'day-cloud-3.jpg',\n  partly_cloudy: 'day-cloud-2.jpg',\n  mostly_clear: 'day-cloud-1.jpg',\n  clear: 'day-clear.jpg',\n};\n"
  },
  {
    "path": "src/iconmodels/im-darksky.ts",
    "content": "export const cwcDarkskyDayIcons: { [key: string]: string; } = {\n  clear: 'day',\n  'clear-day': 'day',\n  rain: 'rainy-2',\n  snow: 'snowy-2',\n  sleet: 'rain-and-sleet-mix',\n  wind: 'cloudy-day-1',\n  fog: 'fog',\n  cloudy: 'cloudy-original',\n  'partly-cloudy-day': 'cloudy-day-2',\n};\n\nexport const cwcDarkskyNightIcons: { [key: string]: string; } = {\n  ...cwcDarkskyDayIcons,\n  clear: 'night',\n  'clear-night': 'night',\n  wind: 'cloudy-night-1',\n  'partly-cloudy-day': 'cloudy-night-2',\n  'partly-cloudy-night': 'cloudy-night-2',\n};\n"
  },
  {
    "path": "src/iconmodels/im-hass.ts",
    "content": "export const cwcDefaultHassDayIcons: { [key: string]: string } = {\n  cloudy: 'cloudy-day-3',\n  exceptional: 'severe-thunderstorm',\n  fog: 'fog',\n  hail: 'snow-and-sleet-mix',\n  lightning: 'severe-thunderstorm',\n  'lightning-rainy': 'scattered-thunderstorms',\n  partlycloudy: 'cloudy-day-3',\n  pouring: 'rainy-6',\n  rainy: 'rainy-5',\n  snowy: 'snowy-6',\n  'snowy-rainy': 'snow-and-sleet-mix',\n  sunny: 'clear-day',\n  windy: 'wind',\n  'windy-variant': 'wind',\n};\n\nexport const cwcDefaultHassNightIcons: { [key: string]: string } = {\n  ...cwcDefaultHassDayIcons,\n  'clear-night': 'clear-night',\n};\n"
  },
  {
    "path": "src/iconmodels/im-openweathermap.ts",
    "content": "export const cwcOpenWeatherMapDayIcons: { [key: string]: string; } = {\n  'clear sky': 'day',\n  'few clouds': 'cloudy-day-1',\n  'scattered clouds': 'cloudy-day-2',\n  'broken clouds': 'cloudy-day-3',\n  'shower rain': 'rainy-3',\n  rain: 'rainy-2',\n  thunderstorm: 'tropical-storm',\n  snow: 'snowy-2',\n  mist: 'fog',\n};\n\nexport const cwcOpenWeatherMapNightIcons: { [key: string]: string; } = {\n  ...cwcOpenWeatherMapDayIcons,\n  'clear sky': 'day-night',\n  'few clouds': 'cloudy-night-1',\n  'scattered clouds': 'cloudy-night-2',\n  'broken clouds': 'cloudy-night-3',\n};\n"
  },
  {
    "path": "src/iconmodels/im-pirateweather.ts",
    "content": "// Pirate Weather Icons\n// clear-day, clear-night, rain, snow, sleet, wind, fog, cloudy, partly-cloudy-day and partly-cloudy-night\n// mostly-clear-day, mostly-clear-night, mostly-cloudy-day, mostly-cloudy-night, possible-rain-day, possible-rain-night\n// possible-snow-day, possible-snow-night, possible-sleet-day, possible-sleet-night, possible-precipitation-day\n// possible-precipitation-night, precipitation, drizzle, light-rain, heavy-rain, flurries, light-snow, heavy-snow\n// very-light-sleet, light-sleet, heavy-sleet, breezy, dangerous-wind\n\nexport const cwcDaytimePirateWeatherIcons: { [key: string]: string; } = {\n  freezing_rain_heavy: 'rainy-3',\n  'heavy freezing rain': 'rainy-3',\n  freezing_rain: 'rainy-2',\n  'freezing rain': 'rainy-2',\n  freezing_rain_light: 'rainy-1',\n  'light freezing rain': 'rainy-1',\n  freezing_drizzle: 'rain-and-sleet-mix',\n  sleet: 'rain-and-sleet-mix',\n  'freezing drizzle': 'rain-and-sleet-mix',\n  ice_pellets_heavy: 'rain-and-snow-mix',\n  'heavy ice pellets': 'rain-and-snow-mix',\n  ice_pellets: 'rain-and-snow-mix',\n  'ice pellets': 'rain-and-snow-mix',\n  ice_pellets_light: 'rain-and-snow-mix',\n  'light ice pellets': 'rain-and-snow-mix',\n  snow_heavy: 'snowy-3',\n  'heavy snow': 'snowy-3',\n  snow: 'snowy-2',\n  snow_light: 'snowy-1',\n  'light snow': 'snowy-1',\n  flurries: 'wind',\n  tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-3',\n  'heavy rain': 'rainy-3',\n  rain_light: 'rainy-1',\n  rainy: 'rainy-1',\n  'light rain': 'rainy-1',\n  rain: 'rainy-2',\n  drizzle: 'rainy-1',\n  fog_light: 'haze',\n  'light fog': 'haze',\n  fog: 'fog',\n  cloudy: 'cloudy-original',\n  mostly_cloudy: 'cloudy-day-3',\n  'mostly cloudy': 'cloudy-day-3',\n  partly_cloudy: 'cloudy-day-2',\n  partlycloudy: 'cloudy-day-2',\n  'partly-cloudy-day': 'cloudy-day-2',\n  'partly cloudy': 'cloudy-day-2',\n  mostly_clear: 'cloudy-day-1',\n  'mostly clear': 'cloudy-day-1',\n  clear: 'day',\n  'clear-day': 'day',\n  wind: 'wind',\n  windy: 'wind',\n  sunny: 'day',\n  'clear-night': 'day',\n};\n\nexport const cwcNightlyPirateWeaterIcons: { [key: string]: string; } = {\n  ...cwcDaytimePirateWeatherIcons,\n  freezing_rain_heavy: 'rainy-6',\n  'heavy freezing rain': 'rainy-6',\n  freezing_rain: 'rainy-5',\n  'freezing rain': 'rainy-5',\n  freezing_rain_light: 'rainy-4',\n  'light freezing rain': 'rainy-4',\n  // freezing_drizzle: 'rain-and-sleet-mix',\n  // ice_pellets_heavy: 'rain-and-snow-mix',\n  // ice_pellets: 'rain-and-snow-mix',\n  // ice_pellets_light: 'rain-and-snow-mix',\n  snow_heavy: 'snowy-6',\n  'heavy snow': 'snowy-6',\n  snow: 'snowy-5',\n  snow_light: 'snowy-4',\n  'light snow': 'snowy-4',\n  // flurries: 'wind',\n  // tstorm: 'tropical-storm',\n  rain_heavy: 'rainy-6',\n  'heavy rain': 'rainy-6',\n  rain_light: 'rainy-4',\n  'light rain': 'rainy-4',\n  rain: 'rainy-5',\n  drizzle: 'rainy-4',\n  // fog_light: 'haze',\n  // fog: 'fog',\n  // cloudy: 'cloudy',\n  mostly_cloudy: 'cloudy-night-3',\n  'mostly cloudy': 'cloudy-night-3',\n  partly_cloudy: 'cloudy-night-2',\n  partlycloudy: 'cloudy-night-2',\n  'partly-cloudy-night': 'cloudy-night-2',\n  'partly cloudy': 'cloudy-night-2',\n  mostly_clear: 'cloudy-night-1',\n  'mostly clear': 'cloudy-night-1',\n  clear: 'night',\n  'clear-night': 'night',\n  sunny: 'night',\n};\n"
  },
  {
    "path": "src/templates/t-camera.ts",
    "content": "import { html } from 'lit';\n\nconst renderCamera = (\n  handlePopup: (e: Event, entityId: string) => void,\n  cameraId: string,\n  cameraPicture: string,\n  friendlyName: string,\n) => {\n  if (!cameraPicture) return html``;\n\n  return html`\n    <div \n      class=\"camera-container\"\n      @click=${(e: Event) => handlePopup(e, cameraId)}\n    >\n      <div class=\"camera-image\">\n        <img \n          src=\"${cameraPicture}\" \n          alt=\"${friendlyName}\"\n          loading=\"lazy\"\n        />\n      </div>\n    </div>\n  `;\n};\n\nexport default renderCamera;\n"
  },
  {
    "path": "src/templates/t-meteoalarm.ts",
    "content": "import { html } from 'lit';\n\nexport interface iWeatherMeteoDPCAlarmDataInterface {\n  event?: string,\n  severity?: string,\n  icon?: string,\n  icon_color?: string,\n  datetime?: string,\n}\n\nconst renderMeteoDPCalarm = (\n  meteoDPCalarmData: Record<string, iWeatherMeteoDPCAlarmDataInterface> | null,\n) => {\n  if (!meteoDPCalarmData || Object.keys(meteoDPCalarmData).length === 0) return html``;\n\n  return html`\n  <div class=\"meteodcpalarm-grid-container\">\n    ${Object.entries(meteoDPCalarmData).map(([key, data]) => html`\n      <div class=\"meteodcpalarm-group\">\n        <ha-icon icon=\"${data.icon}\" style=\"color: ${data.icon_color};\"></ha-icon>\n        <div class=\"meteodcpalarm-label\">${data.datetime}</div>\n        <div class=\"meteodcpalarm-label\">${data.event}</div>\n      </div>\n    `)}\n  </div>\n  `;\n};\n\nexport default renderMeteoDPCalarm;\n"
  },
  {
    "path": "src/templates/t-pollen.ts",
    "content": "import { html } from 'lit';\n\nexport interface iPollenData {\n  name: string;\n  value: number;\n}\n\nconst LEVEL_NAMES = ['basso', 'moderato', 'alto', 'molto-alto', 'estremo'];\n\nconst getLevelIndex = (value: number, levelMin: number, levelMax: number): number => {\n  const range = levelMax - levelMin + 1;\n  const step = range / LEVEL_NAMES.length;\n  const index = Math.floor((value - levelMin) / step);\n  return Math.min(index, LEVEL_NAMES.length - 1);\n};\n\nexport const renderPollen = (data: iPollenData[], levelMin: number, levelMax: number) => {\n  const numLevels = levelMax - levelMin + 1;\n  const levels = LEVEL_NAMES.slice(0, numLevels);\n\n  if (data.length === 0) {\n    return html``;\n  }\n\n  return html`\n    <div class=\"pollen-grid-container\">\n      ${data.map((item) => {\n    const activeIndex = getLevelIndex(item.value, levelMin, levelMax);\n    return html`\n          <div class=\"pollen-stack\">\n            <div class=\"levels\">\n              ${levels.map((levelName, index) => html`\n                <div\n                  class=\"level ${levelName} ${index === activeIndex ? 'active' : ''}\"\n                  title=\"${levelName}\"\n                ></div>\n              `)}\n            </div>\n            <div class=\"pollen-name\">${item.name}</div>\n          </div>\n        `;\n  })}\n    </div>\n  `;\n};\n"
  },
  {
    "path": "src/templates/t-present.ts",
    "content": "import { html } from 'lit';\nimport { getLocale, parseLocalizedNumber } from '../utils/helper';\n\nexport interface iRenderDataItem {\n  value?: number | string | Date;\n  unit?: string;\n  icon?: string;\n  icon_color?: string;\n}\n\nexport interface WeatherData {\n  temperatureHigh?: iRenderDataItem;\n  temperatureLow?: iRenderDataItem;\n  precipitationProbability?: iRenderDataItem;\n  precipitationIntensity?: iRenderDataItem;\n  nextRising?: iRenderDataItem;\n  nextSetting?: iRenderDataItem;\n\n  // precipitation?: iRenderDataItem;\n  humidity?: iRenderDataItem;\n  windBearing?: iRenderDataItem;\n  windSpeed?: iRenderDataItem;\n  pressure?: iRenderDataItem;\n  visibility?: iRenderDataItem;\n}\n\nexport interface iAirQualityData {\n  pm25: iRenderDataItem,\n  pm10:iRenderDataItem,\n  o3: iRenderDataItem,\n  no2: iRenderDataItem,\n  co: iRenderDataItem,\n  so2: iRenderDataItem,\n  epa_aqi: iRenderDataItem,\n  epa_primary_pollutant: iRenderDataItem,\n}\n\nconst isValidInput = (val: unknown): val is string | number => typeof val === 'string' || typeof val === 'number';\n\nconst prepareWeatherPresent = (data: WeatherData, language: string) => {\n  const allItems: iRenderDataItem[] = [];\n\n  const addIfValid = (key: keyof WeatherData, item?: iRenderDataItem) => {\n    if (item?.value === undefined) return;\n\n    allItems.push(item);\n  };\n\n  const pi = data.precipitationIntensity?.value;\n  const pp = data.precipitationProbability?.value;\n\n  if (isValidInput(pi) && isValidInput(pp)) {\n    const locale = getLocale(language);\n    const parsedPI = parseLocalizedNumber(pi, locale);\n    const parsedPP = parseLocalizedNumber(pp, locale);\n\n    if (!Number.isNaN(Number(parsedPI)) && !Number.isNaN(Number(parsedPP)) && parsedPI > 0 && parsedPP > 0) {\n      allItems.push({\n        icon:\n          data.precipitationIntensity.icon ||\n          data.precipitationProbability.icon ||\n          'mdi:weather-rainy',\n        // eslint-disable-next-line max-len\n        value: `${data.precipitationIntensity.value} ${data.precipitationIntensity.unit} / ${data.precipitationProbability.value} ${data.precipitationProbability.unit}`,\n      });\n    }\n  }\n\n  // Temperatura min/max combinata\n  if (\n    data.temperatureLow?.value !== undefined &&\n    data.temperatureHigh?.value !== undefined\n  ) {\n    allItems.push({\n      icon: data.temperatureLow.icon || data.temperatureHigh.icon || 'mdi:thermometer',\n      value: `${data.temperatureLow.value} / ${data.temperatureHigh.value}`,\n      unit: data.temperatureLow.unit || data.temperatureHigh.unit,\n    });\n  }\n\n  const keys: (keyof WeatherData)[] = [\n    'humidity',\n    'pressure',\n    'visibility',\n  ];\n  keys.forEach((k) => addIfValid(k, data[k]));\n\n  // Wind (bearing + speed)\n  // eslint-disable-next-line max-len\n  if (data.windSpeed?.value !== undefined || data.windBearing?.value !== undefined) {\n    allItems.push({\n      icon: data.windSpeed?.icon || 'mdi:weather-windy',\n      value: `${data.windBearing?.value ? `${data.windBearing.value} ` : ''}${data.windSpeed?.value ?? ''}`,\n      unit: data.windSpeed?.unit ? `${data.windSpeed.unit}` : '',\n    });\n  }\n\n  // Sun times\n  ['nextRising', 'nextSetting'].forEach((k) => {\n    const item = data[k as keyof WeatherData];\n    if (item?.value) {\n      allItems.push({\n        icon: item.icon,\n        value: item.value,\n        unit: '',\n      });\n    }\n  });\n\n  return allItems;\n};\n\nconst prepareAirQuality = (data: iAirQualityData, language: string) => {\n  const allItems: iRenderDataItem[] = [];\n\n  const addIfValid = (key: keyof iAirQualityData, item?: iRenderDataItem) => {\n    if (item?.value === undefined) return;\n\n    allItems.push(item);\n  };\n\n  const keys: (keyof iAirQualityData)[] = [\n    'epa_aqi',\n    'epa_primary_pollutant',\n    'pm25',\n    'pm10',\n    'o3',\n    'no2',\n    'co',\n    'so2',\n  ];\n  keys.forEach((k) => addIfValid(k, data[k]));\n\n  return allItems;\n};\n\nexport const renderWeatherPresent = (data, language: string) => {\n  const allItems: iRenderDataItem[] = [];\n\n  const buildBlockLeft = (item: iRenderDataItem) => html`\n    <span class=\"present-value-block\">\n      <ha-icon icon=\"${item.icon}\" style=${item.icon_color ? `color: ${item.icon_color}` : ''}></ha-icon>\n      ${item.value}${item.unit ? html`<span class=\"present-unit\">${item.unit}</span>` : ''}\n    </span>\n  `;\n\n  const buildBlockRight = (item: iRenderDataItem) => html`\n    <span class=\"present-value-block\">\n      ${item.value}${item.unit ? html`<span class=\"present-unit\">${item.unit}</span>` : ''}\n      <ha-icon icon=\"${item.icon}\" style=${item.icon_color ? `color: ${item.icon_color}` : ''}></ha-icon>\n    </span>\n  `;\n\n  allItems.push(...prepareWeatherPresent(data, language), ...prepareAirQuality(data, language));\n\n  const rows = [];\n  for (let i = 0; i < allItems.length; i += 2) {\n    const left = allItems[i];\n    const right = allItems[i + 1];\n\n    if ((left && left.value) || (right && right.value)) {\n      rows.push(html`\n        <div class=\"present-row\">\n          <div class=\"present-left\">${left ? buildBlockLeft(left) : html``}</div>\n          <div class=\"present-right\">${right ? buildBlockRight(right) : html``}</div>\n        </div>\n      `);\n    }\n  }\n\n  return rows.length > 0 ? html`\n    <div class=\"present-grid-container\">\n      ${rows}\n    </div>\n  ` : html``;\n};\n"
  },
  {
    "path": "src/templates/t-summary.ts",
    "content": "import { html, nothing } from 'lit';\n\nexport interface WeatherSummaryInterface {\n  title?: string;\n  moonText?: string | undefined;\n  moonIcon?: string;\n  conditionText: string;\n  conditionIcon: string;\n  temperature?: string;\n  temperatureUnit?: string;\n  feelsLikeTerm?: string;\n  temperatureFeelsLike?: string;\n  temperatureFeelsLikeIcon?: string;\n}\n\nconst renderLightningFlashZigzag = (xPercent: number, yPercent: number, segments: number = 7) => {\n  const width = 10; // larghezza in pixel della viewport SVG\n  const height = 20 + Math.random() * 50;\n\n  const points = [];\n  let x = width / 2;\n  let y = 0;\n\n  for (let i = 0; i < segments; i += 1) {\n    // x += (Math.random() * width - width / 2);\n    // y += height / segments;\n    x += (Math.random() * width * 1.5 - width * 0.75); // maggiore zigzag\n    y += (height / segments) * (0.7 + Math.random() * 0.6); // lunghezza variabile\n    points.push(`${x},${y}`);\n  }\n\n  const pathD = `M${width / 2},0 ${points.map((p) => `L${p}`).join(' ')}`;\n\n  const delay = Math.random() * 15.5;\n  const duration = 0.2 + Math.random() * 0.3 * 33;\n\n  return html`\n    <svg\n      class=\"lightning-svg\"\n      style=\"\n        top: ${yPercent}%;\n        left: ${xPercent}%;\n        animation-delay: ${delay}s;\n        animation-duration: ${duration}s;\n      \"\n      width=\"${width}\" height=\"${height}\" viewBox=\"0 0 ${width} ${height}\">\n      <path d=\"${pathD}\" stroke=\"white\" stroke-width=\"1.5\" fill=\"none\" />\n    </svg>\n  `;\n};\n\nconst renderLightningFlashes = (azimuth: number, distance: number, strikes: number) => {\n  const flashes = [];\n  for (let i = 0; i < strikes; i += 1) {\n    const x = Math.random() * 100;\n    const y = Math.random() * 20;\n    flashes.push(renderLightningFlashZigzag(x, y));\n  }\n  return flashes;\n};\n\nconst renderWeatherSummary = ({\n  title,\n  moonText,\n  moonIcon,\n  conditionText,\n  conditionIcon,\n  temperature,\n  temperatureUnit,\n  feelsLikeTerm,\n  temperatureFeelsLike,\n  temperatureFeelsLikeIcon,\n}: WeatherSummaryInterface) => {\n  const lightningAzimuth = 0; // Replace with actual data\n  const lightningDistanceKm = 0; // Replace with actual data\n  const lightningStrikes = 0; // Replace with actual data\n\n  const showLightning =\n  lightningStrikes > 0 &&\n  typeof lightningAzimuth === 'number' &&\n  typeof lightningDistanceKm === 'number';\n\n  if (conditionIcon || moonText || temperature) {\n    return html`\n    <div class=\"summary-wrapper\">\n      ${showLightning ? html`\n        <div class=\"lightning-background\">\n          ${renderLightningFlashes(lightningAzimuth!, lightningDistanceKm!, lightningStrikes)}\n        </div>\n      ` : nothing}\n      <div class=\"summary-grid-container\">\n        ${conditionIcon ? html`\n          <div class=\"summary-col-left\">\n            <img class=\"weather-condition-icon\" src=\"${conditionIcon}\" alt=\"${conditionText}\" />\n          </div>\n        ` : nothing}\n        ${title ? html`\n          <div class=\"summary-top-right\">\n            <span class=\"weather-city-name\">${title}</span>\n          </div>    \n        ` : nothing}\n        ${moonText ? html`\n          <div class=\"summary-bottom-right-left\">\n            <div class=\"moon-row\">\n              <span class=\"summary-moon-icon\">${moonIcon}</span>\n              <span class=\"summary-moon-text\">${moonText}</span>\n            </div>  \n          </div>   \n        ` : nothing}\n        ${temperature ? html`\n          <div class=\"summary-bottom-right-right\">\n            <div class=\"temperature-block\">\n              <div>\n                <span class=\"temperature\">${temperature}</span>\n                <span class=\"temp-unit\">${temperatureUnit}</span>\n              </div>\n              ${temperatureFeelsLike && html`<div class=\"feels-like\">${feelsLikeTerm} <div>${temperatureFeelsLike} ${temperatureUnit}</div></div>`}\n            </div>  \n          </div>\n          ` : nothing}\n      </div>\n    </div>\n    `;\n  }\n\n  return html``;\n};\n\nexport default renderWeatherSummary;\n"
  },
  {
    "path": "src/templates/t-ultraviolet.ts",
    "content": "import { html } from 'lit';\n\nexport interface RenderDataItem {\n  value?: number | string | Date;\n  unit?: string;\n  icon?: string;\n}\nexport interface RenderData {\n  protectionWindow?: RenderDataItem,\n  currentUVLevel?: RenderDataItem,\n  currentUVIndex?: RenderDataItem,\n  maxUVIndex?: RenderDataItem,\n  currentOzoneLevel?: RenderDataItem,\n}\n\nexport interface RenderSkinData {\n  skinType1: RenderDataItem,\n  skinType2: RenderDataItem,\n  skinType3: RenderDataItem,\n  skinType4: RenderDataItem,\n  skinType5: RenderDataItem,\n  skinType6: RenderDataItem,\n}\n\nconst num = ['I', 'II', 'III', 'IV', 'V', 'VI'];\nconst colors = ['#F1D1B1', '#E4B590', '#CF9F7D', '#B67851', '#A15E2D', '#513938'];\n\nconst getTextColor = (hex: string): string => {\n  const c = hex.replace('#', '');\n  const r = parseInt(c.substr(0, 2), 16);\n  const g = parseInt(c.substr(2, 2), 16);\n  const b = parseInt(c.substr(4, 2), 16);\n  const brightness = (r * 299 + g * 587 + b * 114) / 1000;\n  return brightness > 125 ? '#000' : '#fff';\n};\n\nconst renderUltraviolet = (data: RenderData, skinData: RenderSkinData) => {\n  const allItems: RenderDataItem[] = [];\n\n  const buildBlockLeft = (item: RenderDataItem) => html`\n    <span class=\"ultraviolet-value-block\">\n      <ha-icon icon=\"${item.icon}\" style=\"${item.value === 'on' ? 'color: red;' : ''}\"></ha-icon>\n      ${item.value}${item.unit ? html`<span class=\"ultraviolet-unit\">${item.unit}</span>` : ''}\n    </span>\n  `;\n\n  const buildBlockRight = (item: RenderDataItem) => html`\n    <span class=\"ultraviolet-value-block\">\n      ${item.value}${item.unit ? html`<span class=\"ultraviolet-unit\">${item.unit}</span>` : ''}\n      <ha-icon icon=\"${item.icon}\" style=\"${item.value === 'on' ? 'color: red;' : ''}\"></ha-icon>\n    </span>\n  `;\n  \n  const addIfValid = (key: keyof RenderData, item?: RenderDataItem) => {\n    if (item?.value === undefined) return;\n\n    allItems.push(item);\n  };\n\n  let keys: (keyof RenderData)[] = [\n    'protectionWindow',\n    'currentUVLevel',\n  ];\n  keys.forEach((k) => addIfValid(k, data[k]));\n\n  // UV Level current/max combinata\n  if (\n    data.currentUVIndex?.value !== undefined &&\n    data.maxUVIndex?.value !== undefined\n  ) {\n    allItems.push({\n      icon: data.currentUVIndex.icon || data.maxUVIndex.icon || 'mdi:weather-sunny',\n      value: `${data.currentUVIndex.value} / ${data.maxUVIndex.value}`,\n      unit: data.currentUVIndex.unit || data.maxUVIndex.unit,\n    });\n  }\n\n  keys = [\n    'currentOzoneLevel',\n  ];\n  keys.forEach((k) => addIfValid(k, data[k]));\n\n  const summaryRows = [];\n  for (let i = 0; i < allItems.length; i += 2) {\n    const left = allItems[i];\n    const right = allItems[i + 1];\n    summaryRows.push(html`\n      <div class=\"ultraviolet-row\">\n        <div class=\"ultraviolet-left\">${left ? buildBlockLeft(left) : html``}</div>\n        <div class=\"ultraviolet-right\">${right ? buildBlockRight(right) : html``}</div>\n      </div>\n    `);\n  }\n\n  const skinTypes = [\n    skinData.skinType1,\n    skinData.skinType2,\n    skinData.skinType3,\n    skinData.skinType4,\n    skinData.skinType5,\n    skinData.skinType6,\n  ];\n\n  const renderSkinGrid = html`\n  <div class=\"ultraviolet-skin-type-grid\">\n  ${skinTypes.map((item, i) => {\n    const bgColor = colors[i];\n    const textColor = getTextColor(bgColor);\n    return html`\n      <div\n        class=\"ultraviolet-skin-type-cell\"\n        style=\"background: ${bgColor};\"\n        title=\"Fototipo ${num[i]}\"\n      >\n        <div class=\"ultraviolet-skin-type-label\">${num[i]}</div>\n        <div class=\"ultraviolet-exposure-time\" style=\"color: ${textColor};\">${item.value || '--'}</div>\n      </div>\n    `;\n  })}\n  </div>\n  `;\n\n  return html`\n    <div class=\"ultraviolet-grid-container\">\n      ${summaryRows}\n      ${renderSkinGrid}\n    </div>\n  `;\n};\n\nexport default renderUltraviolet;\n"
  },
  {
    "path": "src/templates/t-weather-forecast.ts",
    "content": "/* eslint-disable max-len */\n/* eslint-disable camelcase */\nimport { html } from 'lit';\n\nexport interface iForecastDataItem {\n  value?: number | string | Date;\n  unit?: string;\n  img?: string;\n  icon?: string;\n  iconColor?: string;\n}\n\nexport const renderWeatherForecast = (forecastType: number, data: Record<string, iForecastDataItem>[]) => {\n  const rows = data.map((dayData) => {\n    const day = dayData.reference?.value;\n    const img = dayData.condition?.img;\n    const icon = dayData.condition?.icon;\n    const iconColor = dayData.condition?.iconColor;\n    const tempLow = dayData.temperature_low?.value;\n    const tempHigh = dayData.temperature_high?.value;\n    const tempHLUnit = dayData.temperature_high?.unit || dayData.temperature_low?.unit;\n    const precipProb: number = Number(dayData.precipitation_probability?.value ?? 0);\n    const precipInt = dayData.precipitation_intensity?.value;\n    const precipUnit = dayData.precipitation_intensity?.unit;\n\n    const temp = dayData.temperature?.value;\n    const tempUnit = dayData.temperature?.unit || dayData.temperature_feelslike?.unit;\n    const temp_feelslike = dayData.temperature_feelslike?.value;\n    const wind_speed = dayData.wind_speed?.value;\n    const wind_speedUnit = dayData.wind_speed?.unit;\n    const wind_bearing = dayData.wind_bearing?.value;\n\n    const wind_wave_height_max = dayData.wind_wave_height_max?.value;\n    const swell_wave_height_max = dayData.swell_wave_height_max?.value;\n    const wave_height_max = dayData.wave_height_max?.value;\n    const wave_direction = dayData.wave_direction?.value;\n    const wave_direction_degrees = dayData.wave_direction?.icon;\n    const wave_height_max_unit = dayData.wave_height_max?.unit;\n\n    return html`\n      <div class=\"weather-forecast-slot\">\n        ${day ? html`<div class=\"weather-forecast-label-slot\">${day}</div>` : ''}\n        ${img ? html`<img class=\"weather-forecast-icon\" src=\"${img}\" alt=\"${img}\" />` : ''}\n        ${icon ? html`<ha-icon icon=\"${icon}\" style=${iconColor ? `color: ${iconColor}` : ''}></ha-icon>` : ''}\n        ${\n  tempLow !== undefined && tempHigh !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${tempLow} / <span class=\"high\">${tempHigh}${tempHLUnit ? ` ${tempHLUnit}` : ''}</span>\n                </div>\n              `\n    : ''\n}\n        ${\n  temp !== undefined && temp_feelslike !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${temp} / <span class=\"high\">${temp_feelslike}${tempUnit ? ` ${tempUnit}` : ''}</span>\n                </div>\n              `\n    : ''\n}\n        ${\n  wind_speed !== undefined && wind_bearing !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${wind_speed} ${wind_speedUnit} ${wind_bearing}</span>\n                </div>\n              `\n    : ''\n}\n        ${\n  wave_height_max !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${wave_height_max} ${wave_height_max_unit ? ` ${wave_height_max_unit}` : ''}\n                </div>\n              `\n    : ''\n}\n        ${\n  wave_direction !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${wave_direction_degrees ? html`<ha-icon\n                        icon=\"mdi:arrow-up-thin\"\n                        style=\"display:inline-block; transform: rotate(${wave_direction_degrees}deg);\"\n                      ></ha-icon>` : ''} ${wave_direction}\n                </div>\n              `\n    : ''\n}\n        ${\n  wind_wave_height_max !== undefined && swell_wave_height_max !== undefined\n    ? html`\n                <div class=\"weather-forecast-temperature\">\n                  ${swell_wave_height_max} / ${wind_wave_height_max} ${wave_height_max_unit ? ` ${wave_height_max_unit}` : ''}\n                </div>\n              `\n    : ''\n}\n        ${\n  precipProb !== undefined && precipInt !== undefined && precipProb !== 0\n    ? html`\n                <div class=\"weather-forecast-precipitation\">\n                  ${precipProb} % / <span class=\"mm\">${precipInt}${precipUnit ? ` ${precipUnit}` : ''}</span>\n                </div>\n              `\n    : ''\n}\n      </div>\n    `;\n  });\n\n  let title = 'Daily';\n  if (forecastType === 1) {\n    title = 'Hourly';\n  } else if (forecastType === 2) {\n    title = 'Marine daily';\n  } else if (forecastType === 3) {\n    title = 'Marine hourly';\n  }\n\n  return html`\n  <div class=\"weather-forecast-grid-wrapper\">\n    <div class=\"weather-forecast-title\">${title} forecast</div>\n    <div class=\"weather-forecast-grid-container\">\n      ${rows}\n    </div>\n  </div>\n  `;\n};\n"
  },
  {
    "path": "src/utils/colors.ts",
    "content": "import { css } from 'lit';\nimport * as Color from 'color';\n\nexport const COLORS = [\n  'primary',\n  'accent',\n  'red',\n  'pink',\n  'purple',\n  'deep-purple',\n  'indigo',\n  'blue',\n  'light-blue',\n  'cyan',\n  'teal',\n  'green',\n  'light-green',\n  'lime',\n  'yellow',\n  'amber',\n  'orange',\n  'deep-orange',\n  'brown',\n  'light-grey',\n  'grey',\n  'dark-grey',\n  'blue-grey',\n  'black',\n  'white',\n  'disabled',\n];\n\nexport function computeRgbColor(color: string): string {\n  if (color === 'primary' || color === 'accent') {\n    return `var(--rgb-${color}-color)`;\n  }\n  if (COLORS.includes(color)) {\n    return `var(--rgb-${color})`;\n  // eslint-disable-next-line no-else-return\n  } else if (color.startsWith('#')) {\n    try {\n      return Color.rgb(color).rgb().array().join(', ');\n    } catch (err) {\n      return '';\n    }\n  }\n  return color;\n}\n\nfunction capitalizeFirstLetter(string) {\n  return string.charAt(0).toUpperCase() + string.slice(1);\n}\n\nexport function computeColorName(color: string): string {\n  return color\n    .split('-')\n    .map((s) => capitalizeFirstLetter(s))\n    .join(' ');\n}\n\nexport const defaultColorCss = css`\n  --default-red: 244, 67, 54;\n  --default-pink: 233, 30, 99;\n  --default-purple: 146, 107, 199;\n  --default-deep-purple: 110, 65, 171;\n  --default-indigo: 63, 81, 181;\n  --default-blue: 33, 150, 243;\n  --default-light-blue: 3, 169, 244;\n  --default-cyan: 0, 188, 212;\n  --default-teal: 0, 150, 136;\n  --default-green: 76, 175, 80;\n  --default-light-green: 139, 195, 74;\n  --default-lime: 205, 220, 57;\n  --default-yellow: 255, 235, 59;\n  --default-amber: 255, 193, 7;\n  --default-orange: 255, 152, 0;\n  --default-deep-orange: 255, 111, 34;\n  --default-brown: 121, 85, 72;\n  --default-light-grey: 189, 189, 189;\n  --default-grey: 158, 158, 158;\n  --default-dark-grey: 96, 96, 96;\n  --default-blue-grey: 96, 125, 139;\n  --default-black: 0, 0, 0;\n  --default-white: 255, 255, 255;\n  --default-disabled: 189, 189, 189;\n`;\n\nexport const defaultDarkColorCss = css`\n  --default-disabled: 111, 111, 111;\n`;\n"
  },
  {
    "path": "src/utils/config-schema.ts",
    "content": "export interface iLovelaceCardConfig {\n  index?: number; // Indice della card all'interno della vista (opzionale).\n  view_index?: number; // Indice della vista in cui si trova la card (opzionale).\n  view_layout?: unknown; // Informazioni di layout (griglia, posizione, ecc.) per l'editor UI.\n  type: string; // Obbligatorio. Indica il tipo di card\n  [key: string]: unknown; // Permette di aggiungere parametri arbitrari, cioè supporta proprietà dinamiche definite dall’utente.\n}\n\nexport interface iPresentData {\n  // sun?: string;\n  // moonphase?: string;\n  condition?: string;\n  temperature?: string;\n  temperature_feelslike?: string;\n\n  temperature_min?: string;\n  temperature_max?: string;\n\n  humidity?: string;\n  pressure?: string;\n  visibility?: string;\n  wind_bearing?: string;\n  wind_speed?: string;\n  precipitation_intensity?: string;\n  precipitation_probability?: string;\n}\n\nexport interface iTimeSlots {\n  slot1: string;\n  slot2: string;\n  slot3: string;\n  slot4: string;\n  slot5: string;\n  slot6: string;\n}\n\nexport interface iDailyForecast {\n  condition?: iTimeSlots;\n  temperature_high?: iTimeSlots;\n  temperature_low?: iTimeSlots;\n  precipitation_intensity?: iTimeSlots;\n  precipitation_probability?: iTimeSlots;\n\n  meteogram?: string ;\n}\n\nexport interface iHourlyForecast {\n  condition?: iTimeSlots;\n  temperature?: iTimeSlots;\n  temperature_feelslike?: iTimeSlots;\n  precipitation_intensity?: iTimeSlots;\n  precipitation_probability?: iTimeSlots;\n  wind_bearing?: iTimeSlots;\n  wind_speed?: iTimeSlots;\n}\n\nexport interface iMarineHourlyForecast {\n  swell_direction?: iTimeSlots ;\n  swell_height?: iTimeSlots ;\n  swell_period?: iTimeSlots ;\n  wind_direction: iTimeSlots ;\n  wind_speed: iTimeSlots ;\n  air_temperature: iTimeSlots ;\n  water_temperature: iTimeSlots ;\n}\n\nexport interface iMarineDailyForecast {\n  wave_height_max?: iTimeSlots ;\n  wave_direction?: iTimeSlots ;\n  swell_wave_height_max?: iTimeSlots ;\n  wind_wave_height_max?: iTimeSlots ;\n}\n\nexport interface iDPCAlert {\n  thunderstorms?: string;\n  hydraulic?: string;\n  hydrogeological?: string;\n}\n\nexport interface iWeather {\n  name?: string; // location name, in summary\n  sun?: string;\n  moonphase?: string;\n  icons_model: string;\n  animation?: boolean;\n  present?: iPresentData ;\n  daily_forecasts?: iDailyForecast;\n  hourly_forecasts?: iHourlyForecast;\n  marine_daily_forecasts?: iMarineDailyForecast;\n  marine_hourly_forecasts?: iMarineHourlyForecast;\n  meteoalarm?: string; // Meteoalarm alert\n  dpcalarm?: iDPCAlert; // DPC alert\n}\n\nexport interface iUltraviolet {\n  protection_window?: string ;\n  ozone_level?: string ;\n  uv_index?: string ;\n  uv_level?: string ;\n  max_uv_index?: string ;\n  set_skin_type_1?: string ;\n  set_skin_type_2?: string ;\n  set_skin_type_3?: string ;\n  set_skin_type_4?: string ;\n  set_skin_type_5?: string ;\n  set_skin_type_6?: string ;\n}\n\nexport interface iPollenItem {\n  name: string;\n  entity: string;\n}\n\nexport interface iPollen {\n  entities: iPollenItem[];\n  min: number;\n  max: number;\n}\n\nexport interface iAirQuality {\n  pm25?: string ;\n  pm10?: string ;\n  o3?: string ;\n  no2?: string ;\n  co?: string ;\n  so2?: string ;\n  epa_aqi?: string ;\n  epa_primary_pollutant?: string ;\n  epa_health_concern?: string ;\n}\n\nexport interface iCardConfig {\n  type: string; // ha-card-weather-conditions\n  language?: string ; // Card language\n\n  weather: iWeather;\n  ultraviolet?: iUltraviolet;\n\n  pollen?: iPollen;\n  airquality?: iAirQuality ;\n\n  camera?: string;\n\n  // display: string[]\n\n  // alert: Alert ;\n  // sea: Sea ;\n}\n"
  },
  {
    "path": "src/utils/const.ts",
    "content": "export const logo: string = '%c WEATHER-CONDITION-CARD %c 2.0.0';\n\nexport const hacsImagePath: string = '/local/community/ha-card-weather-conditions/icons';\nexport const manImagePath: string = '/local/ha-card-weather-conditions/icons';\n\nexport const optConsoleParam1: string = 'color: white; background: green; font-weight: 700;';\nexport const optConsoleParam2: string = 'color: green; background: white; font-weight: 700;';\nexport const optConsoleParam3: string = 'color: black; background: white; font-weight: 700;';\n\nexport const iconTemperature: string = 'mdi:thermometer';\nexport const iconPrecipitation: string = 'mdi:weather-rainy';\n\nexport const cwcLocale = {\n  en: 0,\n  it: 1,\n  nl: 2,\n  es: 3,\n  de: 4,\n  fr: 5,\n  'sr-latn': 6,\n  pt: 7,\n  da: 8,\n  'no-no': 9,\n  cs: 10,\n  ru: 11,\n};\n\n// 🌑 🌒 🌓 🌔 🌕 🌖 🌗 🌘 🌑\nexport const cwcMoonPhaseIcons = {\n  new_moon: '🌑',\n  new: '🌑',\n  waxing_crescent: '🌒',\n  first_quarter: '🌓',\n  waxing_gibbous: '🌔',\n  full: '🌕',\n  full_moon: '🌕',\n  waning_gibbous: '🌖',\n  third_quarter: '🌗',\n  last_quarter: '🌗',\n  waning_crescent: '🌘',\n};\n"
  },
  {
    "path": "src/utils/helper-render.ts",
    "content": "import { css } from 'lit';\n// import { HomeAssistant } from 'custom-card-helpers/dist';\n\nimport { cwcMoonPhaseIcons } from '../../backup/ha-cwc-consts';\n\nimport cardStyle from '../css/css-base-card';\nimport summaryStyles from '../css/css-summary';\nimport presentStyle from '../css/css-present';\nimport ultravioletStyle from '../css/css-ultraviolet';\nimport pollenStyle from '../css/css-pollen';\nimport cameraStyle from '../css/css-camera';\nimport { iIconsConfig } from '../base/lovelace-base';\nimport weatherForecastStyle from '../css/css-weather-forecast';\nimport meteodcpalarmStyle from '../css/css-meteoalarm';\n\nexport const getMoonIcon = (phase: string): string => cwcMoonPhaseIcons[phase.toLowerCase()];\n\nexport const getWeatherIcon = (\n  condition: string,\n  iconsConfig: iIconsConfig,\n  sunState: string,\n): string => {\n  const isNight = sunState === 'below_horizon';\n  const iconMap = isNight ? iconsConfig.iconsNight : iconsConfig.iconsDay;\n  const iconName = iconMap[condition];\n\n  if (!iconsConfig.path) {\n    console.info('Image path not found.');\n  }\n\n  if (!iconName) {\n    console.info(\n      `Icons issue. Model=${iconsConfig.icons_model}, Time=${isNight ? 'night' : 'day'}, Condition=${condition}`,\n    );\n    return '';\n  }\n\n  return `${iconsConfig.path}/${iconsConfig.iconType}/${iconName}.svg`;\n};\n\n// export const getSensorUnit = (hass: HomeAssistant, measure: string): string => {\n//   const lengthUnit = hass.config.unit_system.length;\n\n//   const unitOverrides: Record<string, string> = {\n//     air_pressure: lengthUnit === 'km' ? 'hPa' : 'inHg',\n//     precipitation: lengthUnit === 'km' ? 'mm' : 'in',\n//     length: lengthUnit,\n//   };\n\n//   if (measure in unitOverrides) {\n//     return unitOverrides[measure];\n//   }\n\n//   const unit = (hass.config.unit_system as Record<string, string>)[measure];\n\n//   if (unit !== undefined) {\n//     return unit;\n//   }\n\n//   console.warn(`Unit for '${measure}' not found in hass.config.unit_system.`);\n//   return '';\n// };\n\nexport const getCardStyles = () => css`\n${cardStyle}\n${summaryStyles}\n${presentStyle}\n${weatherForecastStyle}\n${ultravioletStyle}\n${pollenStyle}\n${cameraStyle}\n${meteodcpalarmStyle}\n`;\n"
  },
  {
    "path": "src/utils/helper.ts",
    "content": "/* eslint-disable camelcase */\nimport { HomeAssistant } from 'custom-card-helpers/dist';\nimport { iconsModels } from '../../backup/types';\n\nexport interface IconsConfigResult {\n  iconsModel: string;\n  iconsDay: Record<string, string>;\n  iconsNight: Record<string, string>;\n}\n\n// export const getEntityState = (hass: HomeAssistant, entityId?: string) => (\n//   entityId ? hass.states[entityId]?.state : undefined\n// );\n\n/**\n * Restituisce la traduzione di un termine usando un dizionario, in modo case-insensitive.\n * Se il termine non è trovato, restituisce l'originale.\n */\nexport const translate = (term: string, dictionary: Record<string, string>): string => {\n  const key = Object.keys(dictionary).find((k) => k.toLowerCase() === term.toLowerCase());\n  return key ? dictionary[key] : term;\n};\n\ntype LocaleInfo = {\n  locale: string;\n  timezone: string;\n  cwc?: number;\n};\n\nexport const getLocaleInfo = (lang: string): LocaleInfo => {\n  const localeMap: Record<string, string> = {\n    en: 'en-US',\n    it: 'it-IT',\n    nl: 'nl-NL',\n    es: 'es-ES',\n    de: 'de-DE',\n    fr: 'fr-FR',\n    'sr-latn': 'sr-Latn',\n    pt: 'pt-PT',\n    da: 'da-DK',\n    'no-no': 'nb-NO',\n    cs: 'cs-CZ',\n    ru: 'ru-RU',\n  };\n\n  const timezoneMap: Record<string, string> = {\n    en: 'America/New_York',\n    it: 'Europe/Rome',\n    nl: 'Europe/Amsterdam',\n    es: 'Europe/Madrid',\n    de: 'Europe/Berlin',\n    fr: 'Europe/Paris',\n    'sr-latn': 'Europe/Belgrade',\n    ja: 'Asia/Tokyo',\n    pt: 'Europe/Lisbon',\n    da: 'Europe/Copenhagen',\n    'no-no': 'Europe/Oslo',\n    cs: 'Europe/Prague',\n    ru: 'Europe/Moscow',\n  };\n\n  const cwcLocale: Record<string, number> = {\n    en: 0,\n    it: 1,\n    nl: 2,\n    es: 3,\n    de: 4,\n    fr: 5,\n    'sr-latn': 6,\n    pt: 7,\n    da: 8,\n    'no-no': 9,\n    cs: 10,\n    ru: 11,\n  };\n\n  return {\n    locale: localeMap[lang] || lang,\n    timezone: timezoneMap[lang] || 'UTC',\n    ...(lang in cwcLocale && { cwc: cwcLocale[lang] }),\n  };\n};\n\nexport const getLocale = (lang: string) => {\n  const map = {\n    it: 'it-IT',\n    en: 'en-US',\n    fr: 'fr-FR',\n    de: 'de-DE',\n    es: 'es-ES',\n    ja: 'ja-JP',\n    zh: 'zh-CN',\n    // Aggiungi altri se servono\n  };\n  return map[lang] || `${lang}-${lang.toUpperCase()}`; // fallback generico\n};\n\nexport const getFormatter = (\n  locale: string = 'en-US',\n  fractionDigits: number = 1,\n  useGrouping: boolean = false,\n): Intl.NumberFormat => new Intl.NumberFormat(locale, {\n  minimumFractionDigits: fractionDigits,\n  maximumFractionDigits: fractionDigits,\n  useGrouping,\n});\n\nexport const formatNumber = (\n  {\n    stringNumber,\n    lang = 'en',\n    fractionDigits = 1,\n    useGrouping = false,\n  }: {\n    stringNumber: string;\n    lang?: string;\n    fractionDigits?: number;\n    useGrouping?: boolean;\n  },\n): string => {\n  const number = parseFloat(stringNumber);\n  if (Number.isNaN(number)) return '';\n\n  const effectiveFormatter = getFormatter(getLocale(lang), fractionDigits, useGrouping);\n  // console.debug(`>>>|| ${number} ${effectiveFormatter.format(number)}`);\n  return effectiveFormatter.format(number);\n};\n\nexport const getIconModelData = (iconsModel: string): IconsConfigResult => {\n  const modelName = iconsModel.toLowerCase() ?? 'climacell';\n\n  if (modelName in iconsModels) {\n    const { iconsDay, iconsNight } = iconsModels[modelName];\n    return {\n      iconsModel: modelName,\n      iconsDay,\n      iconsNight,\n    };\n  }\n\n  console.warn(`Unknown icons model: ${modelName}. Falling back to 'climacell'.`);\n\n  const fallback = iconsModels['climacell'];\n  return {\n    iconsModel: 'climacell',\n    iconsDay: fallback.iconsDay,\n    iconsNight: fallback.iconsNight,\n  };\n};\n\nexport function pad(n: number | string, width: number, z = '0'): string {\n  return n.toString().padStart(width, z);\n}\n\n/**\n * Converte una stringa numerica localizzata in un numero.\n * Esempio: '1.234,56' (it-IT) → 1234.56\n * @param input - La stringa o numero da convertire.\n * @param locale - Il locale da utilizzare per determinare i separatori.\n * @returns Il numero convertito o NaN se la conversione fallisce.\n */\nexport const string2Number = (input: string | number, locale: string = 'en-US'): number => {\n  if (typeof input === 'number') return input;\n\n  const formatter = new Intl.NumberFormat(locale);\n  const parts = formatter.formatToParts(1234567.89);\n\n  const group = parts.find((part) => part.type === 'group')?.value || '';\n  const decimal = parts.find((part) => part.type === 'decimal')?.value || '.';\n\n  // Rimuove i separatori delle migliaia e sostituisce il separatore decimale con '.'\n  const normalized = input\n    .replace(new RegExp(`\\\\${group}`, 'g'), '')\n    .replace(new RegExp(`\\\\${decimal}`), '.');\n\n  return Number(normalized);\n};\n\nexport const getEntityRawValue = (hass: HomeAssistant, entityId?: string): string | undefined => (\n  entityId && hass.states[entityId]?.state\n);\n\nexport const getEntityRawAttribute = (hass: HomeAssistant, entityId: string, attribute: string): string | undefined => (\n  entityId && hass.states[entityId]?.attributes[attribute]\n);\n\nexport const getEntityNumericValue = (\n  {\n    entityId,\n    hass,\n    lang = 'en',\n    decimals = 0,\n  }: {\n    entityId?: string;\n    hass?: HomeAssistant;\n    lang?: string;\n    decimals?: number;\n  } = {},\n): string | undefined => {\n  const state = hass && entityId && hass.states[entityId]?.state;\n  return state !== undefined ? formatNumber({ stringNumber: state, fractionDigits: decimals, lang }) : undefined;\n};\n\nexport const getEntityUnit = (hass: HomeAssistant, entityId?: string): string | undefined => (\n  entityId && hass.states[entityId]?.attributes?.unit_of_measurement\n);\n\nexport const getEntityIcon = (hass: HomeAssistant, entityId?: string): string | undefined => (\n  entityId && hass.states[entityId]?.attributes?.icon\n);\n\nexport const getWindDirections = (\n  wd: number | string,\n  cwcLocWindDirections,\n): string | null => {\n  const wdNumber = typeof wd === 'number' ? wd : parseFloat(wd);\n\n  if (Number.isNaN(wdNumber)) {\n    return cwcLocWindDirections[wd] ?? null;\n  }\n\n  if (wdNumber < 0 || wdNumber > 360) {\n    console.error(`Invalid wind direction: '${wd}'. Valid values are between 0 and 360 degrees.`);\n    return null;\n  }\n\n  const directions = [\n    'N', 'NNE', 'NE', 'ENE', 'E', 'ESE',\n    'SE', 'SSE', 'S', 'SSW', 'SW', 'WSW',\n    'W', 'WNW', 'NW', 'NNW',\n  ];\n\n  const index = Math.floor(((wdNumber + 11.25) % 360) / 22.5);\n\n  const dirKey = directions[index];\n\n  return cwcLocWindDirections[dirKey] ?? null;\n};\n\nexport function imageExist(imageSrc: string, timeout = 5000): Promise<boolean> {\n  return new Promise<boolean>((resolve) => {\n    const img = new Image();\n    const timer = setTimeout(() => {\n      img.src = ''; // forza stop\n      resolve(false);\n    }, timeout);\n\n    img.onload = () => {\n      clearTimeout(timer);\n      resolve(true);\n    };\n    img.onerror = () => {\n      clearTimeout(timer);\n      resolve(false);\n    };\n    img.src = imageSrc;\n  });\n}\n\nexport async function loadJSON(full_path_file: string): Promise<string> {\n  try {\n    const response = await fetch(full_path_file);\n    if (!response.ok) {\n      const err = `ERROR retrieving JSON file: '${full_path_file}', status: ${response.status} ${response.statusText}`;\n      console.info(err);\n      throw new Error(err);\n    }\n    console.info(`Locale '${full_path_file}' loaded`);\n    return await response.text();\n  } catch (error) {\n    console.info(`Fetch failed for '${full_path_file}':`, error);\n    throw error;\n  }\n}\n\nexport function logInfo(message: string, ...styles: unknown[]) {\n  console.info(message, ...(styles.length ? styles : []));\n}\n\nexport function parseLocalizedNumber(value: string | number, locale = 'en-US'): number {\n  if (typeof value === 'number') return value;\n\n  // Semplificazione solo per 'it-IT': usa virgola come separatore decimale\n  const normalized = value.replace(/\\./g, '').replace(',', '.');\n  return Number(normalized);\n}\n"
  },
  {
    "path": "tsconfig.json",
    "content": "{\n  \"compilerOptions\": {\n    \"target\": \"es2020\",\n    \"module\": \"esnext\",\n    \"moduleResolution\": \"node\",\n    \"lib\": [\"es2020\", \"dom\", \"dom.iterable\"],\n    \"noEmit\": true,\n    \"noUnusedLocals\": false,\n    \"noUnusedParameters\": false,\n    \"noImplicitReturns\": true,\n    \"noFallthroughCasesInSwitch\": true,\n    \"strict\": true,\n    \"noImplicitAny\": false,\n    \"skipLibCheck\": true,\n    \"resolveJsonModule\": true,\n    \"experimentalDecorators\": true,\n    \"strictNullChecks\": false\n  },\n  \n  \"include\": [\"src/**/*.ts\"],\n  \"exclude\": [\"node_modules\"],\n\n  \"scripts\": {\n    \"start\": \"rollup -c --watch\",\n    \"build\": \"npm run lint && npm run rollup\",\n    \"lint\": \"eslint src/*.ts\",\n    \"rollup\": \"rollup -c\"\n  }\n}"
  }
]