Menu
My wife runs her own tattoo and piercing shop (Inked Fox, if you’re curious). In no time, she’s fallen head over heels for the trade and is absolutely rocking it! But, as any self-employed artist knows, the glamorous side comes with its fair share of grunt work.
One particular challenge? Keeping track of her shop’s stock. Tattoo cartridges, piercing needles, saline sprays – you name it, she’d often find herself mid-booking with a mini-crisis because she forgot to reorder. Cue the frustration (and a newfound talent for improvisation).
So, as a tech geek with a soft spot for solving problems, what could be more fun than whipping up a Home Assistant solution to help her out?
The first question I had to ask myself was if Home Assistant could genuinely simplify this process. A completely automated solution did not seem feasible when you need to keep track of your stock, some manual registration will always be needed.
After some brainstorming, I was confident that I could at least make the process a bit easier than it was right now. Tracking a list of products and their quantities in Home Assistant seemed straightforward. The real challenge was figuring out how to let her easily update the list without constantly having to open the Home Assistant mobile app and updating the products manually.
The solution? NFC! She always keeps her products neatly stored in their original boxes. What if I could put physical NFC cards in these boxes so that when she takes a product out, she simply sets the card out of that box aside? Then, after her booking, she could scan all the cards she set aside before putting them back in the boxes, and voilà – her stock register would be perfectly updated with only a fraction of the manual hassle.
With the plan in place, it was time to get started!
For this project, I used the following tools and products.
Required:
Optional:
The first thing we have to do is getting a complete list of the inventory that she needs to keep track of. For each item, I created a Number helper. You can do this under
Settings > Devices & services > Helpers
For each helper, make sure to include:
The next step is to create a separate page on your dashboard, to display the actual stock lists. My goal is to have two lists, ‘Low Stock’ and ‘Sufficient Stock’, in which the entities are dynamically displayed and hidden based on their stock.
The card type we will be using for this, is template-entity-row by thomasloven. This card type allows us to make changes to the ‘Secondary’ attribute, which I want to use to display the minimum stock a product should have. This plugin can be installed via HACS.
After installing the plugin, go ahead and create two new ‘Manual’ cards. You can use the two templates below. Make sure to adjust the following field for each entity:
type: entities
title: Low Stock
entities:
- type: custom:template-entity-row
entity: input_number.product1
secondary: 'Minimum: 5 units'
state: |
{{ states('input_number.product1') | int }} units
condition: |
{% if states('input_number.product1') | int > 5 %}
false
{% else %}
true
{% endif %}
- type: custom:template-entity-row
entity: input_number.product2
secondary: 'Minimum: 10 units'
state: |
{{ states('input_number.product2') | int }} stuks
condition: |
{% if states('input_number.product2') | int > 10 %}
false
{% else %}
true
{% endif %}
type: entities
title: Sufficient Stock
entities:
- type: custom:template-entity-row
entity: input_number.product1
secondary: 'Minimum: 5 units'
state: |
{{ states('input_number.product1') | int }} units
condition: |
{% if states('input_number.product1') | int > 5 %}
true
{% else %}
false
{% endif %}
- type: custom:template-entity-row
entity: input_number.product2
secondary: 'Minimum: 10 units'
state: |
{{ states('input_number.product2') | int }} stuks
condition: |
{% if states('input_number.product2') | int > 10 %}
true
{% else %}
false
{% endif %}
As you can see, the ‘Low Stock’ and ‘Sufficient Stock’ cards are pretty similar, except that they have the ‘true’ and ‘false’ condition switched around.
Altogether, these two blocks should look like this once all the products are added. You can test their functionality by clicking on a product and reducing the amount until the set threshold, after which it should switch columns.
Now we need to register our NFC tags. I bought a pack of 50 blanc NFC cards from Amazon.nl. These are sturdy, plastic cards that won’t mind a little tattoo ink on them and can easily be stored in the product boxes. However, any writable NFC tag should be capable of doing the job – so pick any kind that fits your use case best!
In order to be able to tell the cards apart, I used a DYMO label writer to print plastic labels with the product names on them.
In order to register the NFC tags, we are going to need a smartphone with the Home Assistant application installed. Go to
Menu > Settings > Companion App > NFC Tags > Write NFC Tag
Leave the identifier as is, and hold the NFC tag against the NFC reader in the Smartphone. The empty card should now have an identifier written to it. You can double check this by going back to the NFC Tags page and picking ‘Read NFC Tag’.
If the write was successful, make sure to note down the identifier that was assigned to the tag. If nothing happens when writing or reading the tag, make sure NFC is enabled on the smartphone and nothing is blocking the sensor. Using a thick case or popsocket should be no issue, but make sure there are no other NFC cards or metal parts between the device and the NFC tag.
After writing an identifier to the NFC tag, we can start on creating the automation. This automation will do two things:
Important to note is that each item will need their own automation, so make sure to use the ‘Categories’ functionality in Home Assistant to keep things tidy!
You can find the YAML template for the automation below. Make sure to replace the following fields with your own data:
alias: NFC - Inked Fox Inventory - Product1
description: ""
trigger:
- platform: tag
tag_id: Product1_tag_id
condition: []
action:
- variables:
entity_id: input_number.product1
- service: input_number.decrement
target:
entity_id: "{{ entity_id }}"
data: {}
- service: notify.All_devices
data:
message: >
{% set quantity = states(entity_id) | float %} Kaart gescand! Voorraad
van {{ state_attr(entity_id, 'friendly_name') }} is {{ quantity | int
if quantity.is_integer() else quantity }} stuks.
mode: single
After following all the steps above, scanning the NFC cards should result in the corresponding product’s stock being reduced by 1 unit, and a notification being sent to your phone confirming this.
My wife has been working with her new system for a week now, and she is stoked about it! Every time she uses a product, she tosses the card aside. After she’s done, she scans all those cards, and voila – inventory is magically updated.
Of course there are ways to improve this system. Introducing a new product still involves a fair bit of manual labor, because you need to:
But the most important thing is that the prototype is working fine and has irrefutably made my wife’s life a little bit easier – and I got to prove once again that there’s always room for a little more tech in your life!