A custom Home Assistant integration that provides:
- No Melucha (
binary_sensor.yidcal_no_melucha
) (e.g., on Shabbos and Yom Tov) - Holiday Sensor (
sensor.yidcal_holiday
) with boolean attributes for every holiday, including: א׳ סליחות, ערב ראש השנה, ראש השנה א׳, ראש השנה ב׳, ראש השנה א׳ וב׳, מוצאי ראש השנה, צום גדליה, שלוש עשרה מדות, ערב יום כיפור, יום הכיפורים, מוצאי יום הכיפורים, ערב סוכות, סוכות א׳, סוכות ב׳, סוכות א׳ וב׳, א׳ דחול המועד סוכות, ב׳ דחול המועד סוכות, ג׳ דחול המועד סוכות, ד׳ דחול המועד סוכות, חול המועד סוכות, הושענא רבה, שמיני עצרת, שמחת תורה, מוצאי סוכות, אסרו חג סוכות, ערב חנוכה, חנוכה, זאת חנוכה, שובבים, שובבים ת״ת, צום עשרה בטבת, ט״ו בשבט, תענית אסתר, פורים, שושן פורים, ליל בדיקת חמץ, ערב פסח, פסח א׳, פסח ב׳, פסח א׳ וב׳, א׳ דחול המועד פסח, ב׳ דחול המועד פסח, ג׳ דחול המועד פסח, ד׳ דחול המועד פסח, חול המועד פסח, שביעי של פסח, אחרון של פסח, מוצאי פסח, אסרו חג פסח, פסח שני, ל״ג בעומר, ערב שבועות, שבועות א׳, שבועות ב׳, שבועות א׳ וב׳, מוצאי שבועות, אסרו חג שבועות, צום שבעה עשר בתמוז, מוצאי צום שבעה עשר בתמוז, ערב תשעה באב, תשעה באב, תשעה באב נדחה, מוצאי תשעה באב, ראש חודש - Erev (
binary_sensor.yidcal_erev
) Turns on at the Alos Erev Shabbos, Yom Tov. Turns off at Candle Lighting - Motzi (
binary_sensor.yidcal_motzi
) Turns on at night Motzi Shabbos, Yom Tov. Turns off at 2AM - Molad (
sensor.yidcal_molad
→friendly
attribute) Full human-friendly Molad string in Yiddish - Full Display Sensor (
sensor.yidcal_full_display
) displays it all in one (e.g פרייטאג פרשת קרח ~ ב׳ ד׳ראש חודש תמוז) - Parsha (
sensor.yidcal_parsha
) weekly Torah portion - Rosh Chodesh Today (
sensor.yidcal_rosh_chodesh_today
) i.e.:א' ד'ראש חודש שבט
if today (after nightfall) is Rosh Chodesh - Special Shabbos sensor for Shabbat specials (שבת זכור, שבת נחמו, etc.)
- Sefiras HaOmer counters in Yiddish with the option to remove nikud (הַיּוֹם אַרְבָּעִים יוֹם שֶׁהֵם חֲמִשָּׁה שָׁבוּעוֹת וַחֲמִשָּׁה יָמִים לָעֹֽמֶר and הוֹד שֶׁבְּיְסוֹד)
- Day Label Yiddish (
sensor.yidcal_day_label_yiddish
) Daily label in Yiddish (e.g. זונטאג, מאנטאג, ערש"ק, מוצש"ק) - Day Label Hebrew (
sensor.yidcal_day_label_hebrew
) Daily label in Hebrew (e.g. יום א' יום ב) - Daily Tehilim (
sensor.yidcal_tehilim_daily
) Five-chapter rotation of Tehilim (e.g. א–ה, ו–ט) - Date (
sensor.yidcal_date
) Current Hebrew date in Yiddish (e.g., כ"ה חשון תשפ"ה) - Zman Erev (
sensor.yidcal_zman_erev
) Next candle-lighting timestamp (Shabbos or Yom Tov eve, sunset - candlelighting_offset from config flow) - Zman Motzi (
sensor.yidcal_zman_motzi
) Next havdalah timestamp (Shabbos or Yom Tov end, sunset + havdalah_offset from config flow) - Perek Avos: current Perek rendered in אבות פרק ה׳
- Morid Geshem/Tal Sensor (
sensor.yidcal_morid_geshem_or_tal
) Indicates when to change the prayer between “Morid HaGeshem”/“Morid HaTal” - Tal U’Matar (
sensor.yidcal_tal_umatar
) Indicates when to change the prayer between “V’sen Tal u’Matar”/“V’sen Beracha” - No Music (
binary_sensor.yidcal_no_music
) Indicates when music is prohibited (e.g., in Sefirah, three weeks) - Upcoming Shabbos Mevorchim (
binary_sensor.yidcal_upcoming_shabbos_mevorchim
)on
if the upcoming Shabbos is Mevorchim - Shabbos Mevorchim (
binary_sensor.yidcal_shabbos_mevorchim
)on
if today is Shabbos Mevorchim - Special Prayer Sensor (
sensor.yidcal_special_prayer
) Aggregates special insertions (e.g., ותן טל, יעלה ויבוא, על הניסים) - Special Shabbos Sensor (
sensor.yidcal_special_shabbos
) Special Shabbat names (שבת זכור, שבת נחמו, etc.) - Sefirah Counter (
sensor.yidcal_sefirah_counter
) Day-count of Sefiras HaOmer - Sefirah Middos (
sensor.yidcal_sefirah_counter_middos
) Middos (qualities) of the day in the Omer count - Zman Talis & Tefilin (
sensor.yidcal_zman_tallis_tefilin
) – Misheyakir: Alos HaShachar + configured offset - Sof Zman Krias Shma (MGA) (
sensor.yidcal_sof_zman_krias_shma_mga
) – end-of-Shema, Magen Avraham - Sof Zman Krias Shma (GRA) (
sensor.yidcal_sof_zman_krias_shma_gra
) – end-of-Shema, Vilna Ga’on - Sof Zman Tefilah (MGA) (
sensor.yidcal_sof_zman_tefilah_mga
) – end-of-prayer, Magen Avraham - Sof Zman Tefilah (GRA) (
sensor.yidcal_sof_zman_tefilah_gra
) – end-of-prayer, Vilna Ga’on - Zman Netz HaChamah (
sensor.yidcal_netz
) – sunrise - Zman Alos HaShachar (
sensor.yidcal_alos
) – dawn - Zman Chatzos (
sensor.yidcal_chatzos_hayom
) – halakhic midday - Zman Plag HaMincha (
sensor.yidcal_plag_mincha
) – 10¾-sha‘ot - Zman Shkiat HaChamah (
sensor.yidcal_shkia
) – sunset - Zman Maariv +60m (
sensor.yidcal_zman_maariv_60
) – 60 min after sunset - Zman Maariv R"T (
sensor.yidcal_zman_maariv_rt
) – 72 min after sunset - Zman Tzies Hakochavim (
sensor.yidcal_tzies_hakochavim
) – stars emergence (sunset + havdalah_offset from config flow) - Zman Chatzos Hayom (
sensor.yidcal_chatzos_hayom
) – midnight of night, - Zman Mincha Gedola (
sensor.yidcal_mincha_gedola
) – earliest Mincha - Zman Mincha Ketana (
sensor.yidcal_mincha_ketana
) – preferred Mincha - Zman Chatzos HaLaila (
sensor.yidcal_chatzos_haleila
) – midnight of night - Upcoming Holiday Sensor (
binary_sensor.yidcal_upcoming_holiday
) - Sof Zman Achilas Chumetz (
sensor.yidcal_zman_achilas_chumetz
) - Sof Zman Sreifes Chumetz (
sensor.yidcal_zman_sreifes_chumetz
) - Ishpizin (
sensor.yidcal_ishpizin
) - אושפיזא דאברהם, אושפיזא דיצחק - Nine Days (
binary_sensor.yidcal_nine_days
) - turns on Rosh Chodesh Av & turns off 10 Av at Chatzos. - Day Type (
binary_sensor.yidcal_day_type
) Indicates the type of the current day (Any Other Day, Shabbos, Yom Tov, Shabbos & Yom Tov, Erev, Motzi, Fast Day, Chol Hamoed, Shabbos & Chol Hamoed) - Yurtzeit Sensor (
sensor.yidcal_yurtzeit
) - Displays today's yurtzeits (flipping at sunset + havdalah_offset), with attributes for each yurtzeit name. - Yurtzeit Weekly Sensor (
sensor.yidcal_yurtzeits_weekly
) - Displays weekly yurtzeits (flipping at Saturday sunset + havdalah_offset), with attributes for each day's yurtzeits.
All date calculations are standalone (no external Jewish-calendar integration) and use your Home Assistant latitude, longitude & timezone.
To ensure you calculate sunrise/sunset on the correct center of your municipality for the Zmanim Sensors (and fix boroughs like Brooklyn in NYC):
- Reverse lookup your HA’s latitude/longitude via Nominatim (OSM) to pull the OSM “city” or—if in New York City—the
city_district
(Brooklyn, Queens, etc.). - Forward geocode only
"City, State"
(no ZIP, no bias) via Nominatim’sgeocode(exactly_one=True)
to snap to the official polygon centroid. - Use TimezoneFinder to resolve your timezone from the final lat/lon.
After adding the integration via UI, go to Settings → Devices & Services → YidCal → Options to set:
Option | Default | Description |
---|---|---|
וויפיל מינוט פארן שקיעה איז הדלקת הנרות |
15 | Minutes before sunset for Erev Shabbos |
וויפיל מינוט נאכן שקיעה איז מוצאי |
72 | Minutes after sunset for Motzaei Shabbos |
וויפיל מינוט נאכן עלות איז טלית ותפילין |
22 | Minutes after Alos HaShachar for Talis & Tefilin (Misheyakir) |
נעם אראפ די נְקֻודּוֹת |
false | Remove Hebrew vowel points from Omer text |
צולייגען באזונדערע סענסאָרס פאר די ימים טובים |
true | Add/remove separate binary sensors for each holiday (they always show as attributes in the holiday sensor) |
Full Display Sensor וויזוי דו ווילסט זעהן דעם טאג ביי די |
yiddish | Choose how to display the day label (Yiddish or Hebrew) |
צולייגען די וועכנטליכע יארצייטן סענסאר |
false | Enable the weekly Yurtzeit sensor |
⚠️ Important: If you previously enabled separate holiday binary sensors and later disable them in Options, those entities will not auto-delete. You must manually remove them via Settings → Entities, or delete and re-add the integration with the holiday sensors option turned off.
The Yurtzeit sensor (sensor.yidcal_yurtzeit
) pulls names from a GitHub-hosted JSON file by default. You can add custom names or mute existing ones using text files in your Home Assistant config directory.
Upon installation or restart, the integration automatically creates a /config/yidcal-data/
folder with two sample files:
custom_yahrtzeits.txt
: For adding your own Yurtzeit names.muted_yahrtzeits.txt
: For hiding specific names from the sensor.
-
Locate the Files: Use HA's File Editor add-on, SSH, or a file transfer tool (e.g., FileZilla) to access
/config/yidcal-data/custom_yahrtzeits.txt
and/config/yidcal-data/muted_yahrtzeits.txt
. -
Custom Yurtzeits (Add Names):
- Format:
Hebrew Date: Full Name
(one per line). - Example:
ט"ו תמוז: רבי פלוני בן רבי אלמוני זי"ע [מחבר ספר דוגמא] תש"א י"ז תמוז: רבי דוגמא בן רבי משל זי"ע תרצ"ב
- Custom names are added to the existing GitHub names for that date.
- Comment out lines with
#
to ignore them (samples are commented by default).
- Format:
-
Muted Yurtzeits (Hide Names):
- Format: Full exact name (one per line, no date needed).
- Copy the exact name from the sensor attributes or GitHub JSON.
- Example:
רבי פלוני בן רבי אלמוני זי"ע [מחבר ספר דוגמא] תש"א רבי דוגמא בן רבי משל זי"ע תרצ"ב
- Muted names are hidden globally (from both GitHub and custom lists).
- Comment out lines with
#
to ignore them.
-
Save and Restart: After editing, save the files and restart Home Assistant (Configuration > Server Controls > Restart). Changes load only on restart.
-
Tips:
- Files support Hebrew/UTF-8; use a text editor that handles it well.
- Invalid lines (e.g., bad format) are silently skipped.
- If files don't exist, restart HA to regenerate samples.
- For large lists, edit on your computer and upload (ensure permissions allow writing if needed).
-
HA 2023.7+
-
Python 3.10+
-
HACS recommended
-
Dependencies installed via manifest:
hdate[astral]==1.1.0
pyluach==2.2.0
zmanim==0.3.1
timezonefinder==6.5.9
geopy==2.4.1
- Open HACS in Home Assistant.
- Search for "YidCal" in the Integrations section.
- Install YidCal.
- Restart Home Assistant.
- Settings → Devices & Services → Add Integration → YidCal
type: conditional
conditions:
- condition: or
conditions:
- condition: state
entity: sensor.yidcal_holiday
attribute: מען פאַסט אַן און
state_not: ""
- condition: state
entity: sensor.yidcal_holiday
attribute: מען פאַסט אויס און
state_not: ""
card:
type: horizontal-stack
cards:
- type: markdown
content: >
{% set start = state_attr('sensor.yidcal_holiday', 'מען פאַסט אַן און') %}
{% set end = state_attr('sensor.yidcal_holiday', 'מען פאַסט אויס און') %}
{% if start %}
<center>
<b><font size="2">מען פאַסט אַן און</font></b><br><br>
<ha-icon icon="mdi:clock-start" style="width:24px;height:24px;"></ha-icon><br><br>
<b><font size="5">{{ start }}</font></b>
</center>
{% elif end %}
<center>
<b><font size="2">מען פאַסט אויס און</font></b><br><br>
<ha-icon icon="mdi:clock-end" style="width:24px;height:24px;"></ha-icon><br><br>
<b><font size="5">{{ end }}</font></b>
</center>
{% endif %}
text_only: true
By Yoel Goldstein / Vaayer LLC