Add support for modding badges
This commit is contained in:
		
							parent
							
								
									ab2ccd6954
								
							
						
					
					
						commit
						5ab9c62cd8
					
				
							
								
								
									
										34
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								README.md
									
									
									
									
									
								
							| @ -140,6 +140,40 @@ entities: | ||||
|       } | ||||
| ``` | ||||
| 
 | ||||
| ## Styling badges | ||||
| 
 | ||||
| Badges can be styled too, with the base style applied to `:host`. | ||||
| Note that to change the color of a badge, you need to override the variable for it's default color. I.e. the badges in the example below are normally red, thus the `--label-badge-red` variable is set. | ||||
| 
 | ||||
| ```yaml | ||||
| badges: | ||||
|   - entity: sun.sun | ||||
|     name: Original | ||||
|   - entity: sun.sun | ||||
|     style: | | ||||
|       :host { | ||||
|         --label-badge-red: purple; | ||||
|       } | ||||
|     name: Purple | ||||
|   - entity: sun.sun | ||||
|     name: Teal | ||||
|     style: | | ||||
|       :host { | ||||
|         --label-badge-red: teal; | ||||
|       } | ||||
|   - entity: sun.sun | ||||
|     name: Dashed | ||||
|     style: | ||||
|       ha-state-label-badge: | ||||
|         $: | ||||
|           ha-label-badge: | ||||
|             $: | | ||||
|               .label-badge { | ||||
|                 border-style: dashed !important; | ||||
|               } | ||||
| ``` | ||||
|  | ||||
| 
 | ||||
| ## Templating | ||||
| Jinja templates have access to a few special variables. Those are: | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										25
									
								
								src/hui-state-label-badge.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								src/hui-state-label-badge.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | ||||
| import {fireEvent} from "card-tools/src/event.js"; | ||||
| import {applyStyle} from "./apply-style.js"; | ||||
| 
 | ||||
| customElements.whenDefined('hui-state-label-badge').then(() => { | ||||
|     const HuiStateLabelBadge = customElements.get('hui-state-label-badge'); | ||||
| 
 | ||||
|     HuiStateLabelBadge.prototype.firstUpdated = function() { | ||||
|         const config = this._config; | ||||
|         if(!config || !config.style) return; | ||||
| 
 | ||||
|         let entity_ids = config.entity_ids; | ||||
| 
 | ||||
|         const apply = () => { | ||||
|           applyStyle(this.shadowRoot, config.style, { | ||||
|               variables: {config}, | ||||
|               entity_ids | ||||
|             }, !!config.debug_cardmod); | ||||
|         } | ||||
| 
 | ||||
|         apply(); | ||||
|         window.addEventListener("location-changed", () => apply()); | ||||
|       } | ||||
| 
 | ||||
|     fireEvent('ll-rebuild', {}); | ||||
| }); | ||||
| @ -2,4 +2,5 @@ import "./card-mod"; | ||||
| import "./ha-card"; | ||||
| import "./hui-entities-card"; | ||||
| import "./hui-glance-card"; | ||||
| import "./mod-card" | ||||
| import "./hui-state-label-badge"; | ||||
| import "./mod-card" | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user