github thomasloven/lovelace-card-mod v4.0.0-beta.4
Card-mod 4.0.0-beta.4

pre-releaseone day ago

BETA releases

Card-mod 4.0.0 will progress through a beta program so you can try out the updates, but at the same time we can make sure that 4.0.0 is ready for widespread release. Depending on your setup, you may need to revert to 3.4.5 until issues with the beta are fixed.

Thanks to @Mariusthvdb, LiQuid_cOOled, @ildar170975 who have taken part testing 4.0.0 during an alpha phase. Due to this thorough testing we are confident that most major issues have surfaced and been worked through. However this is not a guarantee hence the need for a beta program.

IMPORTANT: Upgrading when using Frontend module.

If you use Frontend module, as described HERE (instructions updated for v4) you will need to make sure that your Frontend resource module matches the Dashboard resources URL EXACTLY. v4 has an updated mechanism to prevent duplicate patching, but your Frontend resource module will not be up to date and your Browser may run old code. You can tell if this is your scenario as you will likely have console errors about missing functions. Future v4 upgrades should not error, but you should always update your Frontend module URL after upgrading via HACS.

BREAKING

Due to the change from patching <hui-card> in preference of <ha-card> there may be some changes required to your card_mod targets and/or styles as the class will now be on the card element (child of <hui-card>) rather than <ha-card>. For example, if you have targeted your CSS style rule to ha-card.myClass { ... }, the best direct change is to use :host(.myClass) ha-card { ... }.

Support for any migration of existing config due to changes in 4.0.0 will be managed through the Community Forum threads. Any such issue raised in GitHub will be closed and you will be directed to one of the community threads. This is to make sure that card_mod maintainers can focus on issues that require a fix in code, rather than just assisting users in the migration.

What's Changed

  • card-mod now prefers styling via parent <hui-card> which is the wrapper for the majority of standard Home Assistant cards. <ha-card> is still supported as a secondary styling parent where <hui-card> is not the parent of the element containing <ha-card>. The implementation of this change should reduce substantially the need for mod-card as a card wrapper.
  • card-mod now supported for badges <hui-badge>
  • Cancel searching for and styling child elements when parent element is disconnected from DOM. This will give varying performance improvements, especially when switching views.
  • Manage patch state at window level. This prevents duplicate patching fixing various issues when card-mod is loaded twice.
  • Support styling strategy (strategy:) and grid sections (type: grid) in dashboard views.
  • Support card-mod theming in config panels, developer tools, custom panels and element <ha-app-top-bar-fixed>. Theme variables are card-mod-config, card-mod-panel-custom and card-mod-top-app-bar-fixed. NOTE: iFrame custom panels, include HASS Addons and HACS are not supported
  • README.md: Add HACS install link

Since 4.0.0-beta.2

  • Pass through debug: config from mod-card to card-mod
  • Remove console errros
  • Wait for themes to be ready on page refresh

Since 4.0.0-beta.3

  • Fix console errors on refresh and/or loading themes due to styling disconnected elements and/or pruning cancelled children. (Issue #463)

Since 4.0.0-beta.4

  • Prevent incorrect class="undefined"
  • Template debugging. Add {# card_mod.debug #} in your templates to enable template debugging. Console logs will show binding, reuse, value updated, unbinding, cooldown and unsubscribing.
  • Template cooldown. Templates will remain in cache for 20s as a cooldown. This means when changing views quickly, or using views that reuse templates, that templates are not unsubscribed from server but will be reused and available with latest value.
  • Panel variable now available in templates. Variables and example included below.
panel.fullUrlPath: "card-mod/another-test-view"
panel.panelComponentName: "lovelace"
panel.panelIcon: "mdi:card-bulleted-outline"
panel.panelNarrow: true
panel.panelRequireAdmin: false
panel.panelTitle: "Card Mod"
panel.panelUrlPath: "card-mod"
panel.panelTitle: "Card Mod - Test View"
panel.viewNarrow: true
panel.viewTitle: "Test View"
panel.viewUrlPath: "another-test-view"
  • hash variable now dynamic with template updated when has changes.

Fixes

  • README.md: Better frontend_module_url: instructions in performance section

New Contributors

Thank you to the contributions from

Full Changelog: v3.4.5...v4.0.0-beta.4

Don't miss a new lovelace-card-mod release

NewReleases is sending notifications on new releases.