Skip to content

TrashCard - indicates what type of trash will be picked up next based on your calendar entries πŸ—‘οΈ

License

Notifications You must be signed in to change notification settings

maxyvon/hassio-trash-card

Β 
Β 

Repository files navigation

πŸ—‘οΈ TrashCard

hacs release downloads Build

Buy Me A Coffee

Cover

OrganicOther TrashPaperRecycleWaste

TrashCard - is a custom Home Assistant card that shows you the next upcoming or current trash removal appointment. For this purpose a calendar entity is used, in which you have entered all appointments.

Features

  • Extra color, icon and text for residual, organic, paper waste and recycling
  • Color and icon for all other appointments
  • Filter out unexpected items

Restrictions Currently only full day appointments are supported

Pre-Requirements

TrashCard requires Mushroom for Home Assistant to be installed. Please follow the installation instructions of Mushroom. Once you have installed Mushroom you can continue install TrashCard using HACS (preferred) or manually.

TrashCard requires a calendar to get its data from. This calendar must be known by Home Assistant as an entity. Check Home Assistant calednar integrations for more information on how to add it.

Installation

HACS

TrashCard is available in HACS (Home Assistant Community Store).

  1. Install HACS if you don't have it already
  2. Open HACS in Home Assistant
  3. Go to "Frontend" section
  4. Click button with "+" icon
  5. Search for "TrashCard"

Manual

  1. Download trashcard.js file from the latest release.
  2. Put trashcard.js file into your config/www folder.
  3. Add reference to trashcard.js in Dashboard. There's two way to do that:
    • Using UI: Settings β†’ Dashboards β†’ More Options icon β†’ Resources β†’ Add Resource β†’ Set Url as /local/trashcard.js β†’ Set Resource type as JavaScript Module. Note: If you do not see the Resources menu, you will need to enable Advanced Mode in your User Profile

    • Using YAML: Add following code to lovelace section.

      resources:
        - url: /local/trashcard.js
          type: module

Usage

Create events in your calendar

In order for the Trash card to display informations, they need to be existing in a calendar. Here's some rules to follow when creating the events in your calendar:

  1. It must be entire day events (only form of events supported at the moment)
  2. You must use the same event name for the same method of collection. You'll map them later. Right now, the card support up to 5 different type of collections
  3. You can use repeating events, that's totally fine.

Configuration

The TrashCard cards can be configured using Dashboard UI editor.

Add a new card

  1. In Dashboard UI, click 3 dots in top right corner.
  2. Click Edit Dashboard.
  3. Click Plus button to add a new card.
  4. Find the Custom: TrashCard card in the list.

Configure the card

Here's simple steps to follow to configure the trash card with the UI, we'll go throw all the differents configuration field with you: O

  1. First, you need to select your calendar entity in the first field Entity (can be different because it's translated in your own language).
  2. Then, for all the different collection, you'll have to fill those fiels: a. Label is the text you want to be displayed in your card. It can be anything b. Icon is the icon you can to be used in your card. You can select through the availabla HA icons, and even start typing to search c. Color is the color you want your card to be. ⚠️ it's not gonna be the color of the icon but of the card itself d. Pattern is the event title you used when creating events in your calendar. For example, for recycling, mine is "PMC", because that's the event name in my calendar.
  3. day style is how to display the information. Full date or "in xx days"
  4. drop today events from is at which hour you want to stop displaying today's collection
  5. next days is how many days in the future the card will look up. If there is no upcoming event in the next XX days you selected here, the card will not display at all.

O

All the options are available in the lovelace editor but you can use yaml if you want.

Name Type Default Description
entity string Required Entity
layout string Optional Layout of the card. Vertical, horizontal and default layout are supported
fill_container boolean false Fill container or not. Useful when card is in a grid, vertical or horizontal layout
filter_events boolean false Filter fetched events by patterns (if at least one is defined) before selecting the one to display
full_size boolean false Show the card without the default card margins
drop_todayevents_from time 10:00:00 From what time to hide all-day event (Format hh:mm:ss)
use_summary boolean false Shows the event summary instead of matched label
next_days number 2 How many times the card will look into the future to find the next event
day_style default or counter default Option of how the date of an event should be displayed. default shows the date in date format and counter shows the number of days remaining until the event.
settings Settings Required Settings to detect the kind of trash and how to display it.

Settings

Name Type Default Description
organic TrashTypeConfig Required Configuration to detect and display that the organic trash is picked up
paper TrashTypeConfig Required Configuration to detect and display that the paper trash is picked up
recycle TrashTypeConfig Required Configuration to detect and display that the organic trash is picked up
waste TrashTypeConfig Required Configuration to detect and display that the waste trash is picked up
others OtherConfig Required Configuration what should be display if non of the others types are matching

Trash type configuration

Name Type Default Description
label string Required Label which should be shown
icon string Required Icon which should be displayed
color string Required Background color of the card which should be used
pattern string Required Pattern used to detected to display the apply this trash type. (Is tested against the calendar entry title)

Other type trash configuration

Name Type Default Description
icon string Required Icon which should be displayed
color string Required Background color of the card which should be used

Example YAML configuration

type: custom:trash-card
entity: calendar.mags_abfuhrtermine
layout: vertical
settings:
  others:
    color: purple
    icon: mdi:trash-can
  organic:
    label: Organic
    icon: mdi:flower
    color: green
    pattern: (braun)
  paper:
    label: Paper
    icon: mdi:newspaper-variant-multiple
    color: blue
    pattern: (blau)
  recycle:
    label: Recycle
    icon: mdi:recycle-variant
    color: amber
    pattern: (gelb)
  waste:
    label: Trash
    icon: mdi:trash-can-outline
    color: grey
    pattern: (grau)

Thanks

Thanks go to the team at Mushroom for creating many beautiful cards.

About

TrashCard - indicates what type of trash will be picked up next based on your calendar entries πŸ—‘οΈ

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 94.9%
  • JavaScript 5.1%