An insanely customizable way to interact with Home Assistant in the menubar
To use a prebuilt version...
- Head over to releases and download the latest release
- Extract the zip and drag the application into your
Applications
folder. - Open HA Menu
To build it yourself...
- Clone this repository
- Run
yarn install
- Run
yarn dist
- Your executable will be found in the newly created
dist
folder
To open the Preferences window, click the Home Assistant Icon in your menubar, and then go to Preferences
.
-
- The URL to your server. Don't add a
/
or a port to the end of the URL.
-
- The port to your server. If you use https make sure you put in port
443
.
-
- Your long lived access token from home assistant. To make one go to Your Profile -> Long-Lived Access Tokens
The refresh interval is how often the menubar will automatically refresh with new data. If set to never, the menubar will never automatically refresh, but a refresh can still be triggered from a Menu Item.
In the preferences window, you can export your configuration as a .bar
file. You can also import .bar
configuration files from the preferences window. If you want a shortcut to import configuration files, you can hold Shift while clicking Preferences
in the menubar or you can just double click on a .bar
file.
The icon downloader allows you to easily download icons from materialdesignicons.com
. I would recommend searching for icons on their website, then downloading them with the downloader. You can open the Icon Downloader
by clicking Icon Downloader
in the preferences window. All downloaded icons are stored in the Icons Folder
.
-
- The materialdesignicons name of the icon
-
- The size of the icon
-
- The color of the icon
-
- The path the file with be stored at. This is just a path that gets added on to the icons folder path, so you can use slashes to go into folders
In the preferences window, under Config
is where you will put the JSON which creates your custom menubar.
- required
items
{[MenuItem
]}: Your list of menu items - templatable
title
{String
} : The text that will show up next to the Home Assistant icon in the MenuBar. Limited to 34 charachters. - templatable
icon
{String
}: Name of the icon you wish to use
{
"items": [
{
"type": "label",
"label": "So much customization!"
}
],
"title": "Hello World!",
"
}
The title shows to the right of the icon in the menu bar. The title can be set by adding the title
key to the main JSON. The title should be a string and templating is supported (scroll down for more info on templating).
{
"items": [],
"title": "Hello!"
}
- The title is limited to 24 characters
There are 4 types of Menu Items
- Label
- Dropdown
- Separator
- Open HASS
- required
type
:label
- templatable
label
{String
}: The label for this Menu Item - templatable
icon
{String
}: The icon name for this item reload
{Boolean
}: Whether or not the Menu Bar should be reloaded on clickaction
{MenuAction
}: The action to run when clickedcheckedTemplate
{String
}: Whether or not this label should be checked. The string is a Home Assistant template which should resolve toon
,true
,off
, orfalse
. When clicked the check will toggle IN THE UI ONLY. I would recommend making the action some sort of toggle, and havingreload
set totrue
.hiddenTemplate
{String
}: Whether or not this label should be hidden. The string is a Home Assistant template which should resolve toon
,true
,off
, orfalse
.
- If an item has no
action
andreload
is not true, the item will be greyed out.
{
"type": "label",
"label": "No Action"
},
{
"type": "label",
"label": "Reload",
"reload": true
},
{
"type": "label",
"label": "Checked + Reload",
"reload": true,
"checkedTemplate": "true"
},
{
"type": "label",
"label": "Action",
"action": {
"domain": "light",
"service": "toggle",
"serviceData": {
"entity_id": "light.my_light"
}
}
}
Creates a dropdown menu
- required
type
:dropdown
- required templatable
label
{String
}: The label for this dropdown - required
items
{[MenuItem
]}: A list of Menu Items to be displayed - templatable
icon
{String
} : The icon name for this item
{
"type": "dropdown",
"label": "Dropdown",
"items": [
{
"type": "label",
"label": "Item 1"
},
{
"type": "label",
"label": "Item 2"
},
{
"type": "label",
"label": "Item 3"
}
]
}
- required
type
:separator
{
"type": "normal",
"label": "Item 1"
},
{
"type": "separator"
},
{
"type": "normal",
"label": "Item 2"
}
Looks like a label but opens Home Assistant in your browser when clicked.
- required
type
:open_hass
- required templatable
label
{String
}: The label for this item icon
templatable {String
}: The icon name for this item
A MenuAction
is how you can interact with Home Assistant.
- required
domain
{String
}: The domain to be called - required
service
{String
}: The service of the domain - required
serviceeData
{{Service Data
}}: The data that will be given when the service is called
{
"domain" : "light",
"service": "toggle",
"serviceData": {
"entity_id": "light.my_light"
}
}
To add an icon to your Menu Bar follow these steps
- Open Preferences
- Click
Open Icons Folder
- Put all icons in the folder that opens
- On your
MenuItem
add theicon
field and enter the name of the file including the file extension
- Make the size of your image
32x32
- Add
@2x
to the end of your file name to make it a "High Resolution Image" (Read below for more information) - Get icons from here. Export them as PNG at 36x66 then use @2x magnification
To make your image look better in the Menubar you can make it "High Resolution" which increases the DPI. Here are the following options:
@1x
@1.25x
@1.33x
@1.4x
@1.5x
@1.8x
@2x
@2.5x
@3x
@4x
@5x
Just add one of these to the end of your file.
icon.png
-> icon@2x.png
It is recommended that your icons are made a template. To make your icon a template
- Your image must be only black pixels with a transparent background
- Add
Template
to the end of the name of your file.
icon.png
->iconTemplate.png
icon@2x.png
->iconTemplate@2x.png
The customization is not over! You can also use Home Assistant Templates in certain fields!
label
icon
title
To make a field a template just add Template
to the end of the field name and put your template in the value.
{
"label": "State of my light"
}
Turns into...
{
"labelTemplate": "{{ states('light.my_light') }}"
}