Home Assistant 101: Creating and Using Packages

  Рет қаралды 5,114

ResinChem Tech

ResinChem Tech

Күн бұрын

Пікірлер: 17
@MH-ie1sg
@MH-ie1sg 7 ай бұрын
Thanks! This video was a great help for a newbie like me! Helped me out a lot! Thanks for you trouble and effort making this video. 👍
@ResinChemTech
@ResinChemTech 7 ай бұрын
You are most welcome. Glad you found it helpfu.
@rodneysmith1750
@rodneysmith1750 10 ай бұрын
Thanks for today's video about packages, it's still too early in my journey for me to need this but it is good to have an understanding. Something that old-time programmers used and lived by were automatically generated cross-reference listings which showed everywhere a label was used in a program and where it was defined, either locally or externally, that may apply here as well.
@ResinChemTech
@ResinChemTech 10 ай бұрын
I definitely find that as my Home Assistant grows larger and both Home Assistant and I get older, the more important my documentation becomes! Unlike development in a group environment, my comments and documentation are primarily just for me (unless I am sharing my YAML). But I find the ability to add these comments, and organize my YAML in a way that helps me recall 'why' a couple of years down the road invaluable. As always, thanks for the comment!
@arkie87
@arkie87 Ай бұрын
THIS IS THE VIDEO I NEEDED. As far as I can tell, the cons can all be mitigated if you create another package called "globals" that the other packages can use, or you can even split out the globals into multiple other packages. No?
@ResinChemTech
@ResinChemTech Ай бұрын
Well, Home Assistant doesn't have "global" variables... at least not like you might find in standard languages like Python or C++. Nor can you #include the contents of one file in another. However, you can create helpers... like numeric and text strings. These entities would then be available to use anywhere else within Home Assistant. In fact, tomorrow's video is going to cover a handful of these input helper entities. You can also add parameters, fields and other variable options to automations and scripts and then pass the value of these variables to the automation/script when you call it. So I suppose you could 'sorta' create a package that contained various manually-created YAML helper entities and then use these entities in a similar manner to global variables found in other languages. Depending upon your particular situation, this might be another way to organize your packages.
@arkie87
@arkie87 Ай бұрын
@@ResinChemTech Well, they dont have global variables per say, but my intention was you could put all entities used by multiple packages into its own package. Call it whatever you want. I would call it global to indicate that all the other packages in the same folder use it. But are you saying that one package cannot use an entity defined in another package? That isnt true...
@t3chrs
@t3chrs 10 ай бұрын
For the “Where the heck” problem. Most editors (VSCode, vim, etc. ) have a feature that easily and quickly lets you search all the files in a directory. Software developers use this all the time to find which file a piece of code resides in.
@Equality7-2521
@Equality7-2521 6 ай бұрын
Hi, your Home Assistant 101 tutorials are concise and informative. Does the packages: domain need to go directly under the homeassistant:: domain? I ask this question as I do not have, nor ever had the homeassistant:: domain in my configuration.yaml file. Don't know were it is, default_config?? I am running the following versions baremetal on a NUC. Core 2024.6.4 Supervisor 2024.06.2 Operating System 12.4 Regards Jon
@ResinChemTech
@ResinChemTech 6 ай бұрын
The default_config provides a number of default integrations. If you remove it, you are basically 'taking over' the configuration or moving to an 'advanced' configuration and you would have to add back any of the default integrations that you use manually. However, after a little searching, it looks like you can add the homeassistant: section just above the default_config: line and specify your package include statement under that. For example (and don't try to copy/paste this from here as I'm sure spaces and indentation would be lost and I'm using periods to represent spaces... don't use periods in your YAML)... homeassistant: ..packages: !include_dir_named packages default_config: _then the rest of your config_ I haven't tested this, but others report that it works. As always, validate your YAML before restarting Home Assistant and you an always remove the new homeassistant: section if it throws an error.
@Equality7-2521
@Equality7-2521 6 ай бұрын
@@ResinChemTech Thanks for the quick reply, I will try this.(In the morning, I live in the land down under!) I still have default_config in configuration.yaml. Again, thanks for your great content and informative replies.
@Equality7-2521
@Equality7-2521 6 ай бұрын
@@ResinChemTech That works😃 ``` homeassistant: packages: !include_dir_named packages # Loads default set of integrations. Do not remove. default_config: ``` As I hvae a new/clean HASS installation I will use a combination of splitting and packages, thanks.
@ResinChemTech
@ResinChemTech 6 ай бұрын
Great! Thanks for letting me know. I might be able to pass it along to someone else down the road. I never had a default_config as that came along well after I started using Home Assistant. But I'm happy that it worked out for you... and you are wise to get an organizational structure setup from the start.
@BlindGuyNAR
@BlindGuyNAR 10 ай бұрын
In packages, how does the automation editor work? Are they all listed still in the automation section or you edit them yaml only? If they show under normal editor do they just seamlessly get edited in the package file? Same question about the script editor. I know you’re a yaml guy first so you might never use the UI editor. I was just curious on how the script editor and the automation editor worked with packages.
@ResinChemTech
@ResinChemTech 10 ай бұрын
Unfortunately, no. The automation and script editors only work with the YAML files that are auto-generated in the default automations.yaml and scripts.yaml files. If you move or create YAML in any other files, the UI editors cannot be used and you have to manually edit the YAML for any future changes. So it is a bit of a trade-off. You are correct that I always do everything manually in YAML (because that's all there was when I first started), but it does allow me to add comments/documentation to the YAML and organize my files; something that isn't possible with the auto-generated YAML files that are created via the UI editors.
MQTT and Home Assistant: An Abridged Version
10:55
ResinChem Tech
Рет қаралды 7 М.
Home Assistant 101: Splitting Your Configuration
22:33
ResinChem Tech
Рет қаралды 7 М.
Chain Game Strong ⛓️
00:21
Anwar Jibawi
Рет қаралды 41 МЛН
Что-что Мурсдей говорит? 💭 #симбочка #симба #мурсдей
00:19
Try this prank with your friends 😂 @karina-kola
00:18
Andrey Grechka
Рет қаралды 9 МЛН
Home Assistant 101: Input Booleans and Timers
18:55
ResinChem Tech
Рет қаралды 17 М.
5 HACS Frontend Components that will make your data and UI look great
19:57
MQTT 101: Integrate your DIY Devices into Home Assistant
28:06
ResinChem Tech
Рет қаралды 81 М.
ChatGPT in Home Assistant for LESS than $0.01 a DAY!!!
19:30
Daniel Barczak
Рет қаралды 5 М.
Home Assistant 101: Troubleshooting Automations
12:30
ResinChem Tech
Рет қаралды 7 М.
Home Assistant Scripts Hidden Feature!
9:24
SlackerLabs
Рет қаралды 19 М.
Home Assistant 2024: Fully Pardoned?
12:44
ResinChem Tech
Рет қаралды 6 М.
Home Assistant 101: How to Integrate MQTT Devices
28:52
ResinChem Tech
Рет қаралды 44 М.
Home Assistant 101: Input Numbers, Texts and Selects
24:16
ResinChem Tech
Рет қаралды 5 М.
Chain Game Strong ⛓️
00:21
Anwar Jibawi
Рет қаралды 41 МЛН