Web Analytics

my-skylight-calendar

⭐ 248 stars Persian by mohesles

🌐 زبان

تقویم خانوادگی هوشمند DIY (شبیه‌ساز Skylight)

تقویم Sklylight Skylight DIY

📖 مقدمه

همسرم اخیراً در شبکه‌های اجتماعی با تبلیغات تقویم‌های هوشمند خانگی (Skylight، Cozyla، Hearth) بمباران شده بود و آماده بود بیش از ۳۰۰ دلار برای یکی از آن‌ها هزینه کند. قبل از اینکه اجازه خرید بدهم، از او خواستم فرصتی به من بدهد تا درباره‌شان تحقیق کنم.

متوجه شدم که اکثر گزینه‌ها عملکرد مشابهی ارائه می‌دهند اما تفاوت قابل‌توجهی در قیمت دارند. مهم‌تر از همه، هیچ ویژگی برجسته‌ای ندیدم که نتوانم آن را در Home Assistant پیاده‌سازی کنم.

هدف: یک تقویم لمسی رومیزی مورد تأیید WAF (عامل پذیرش همسر) که به طور عمیق با خانه هوشمند ما ادغام شود و هیچ هزینه ماهیانه‌ای نداشته باشد.

💡 چرا DIY؟

انتخاب مسیر DIY با Home Assistant مزایای متعددی نسبت به خرید نمایشگر Skylight/Hearth داشت:

🛠 انتخاب سخت‌افزار

در حال حاضر این پروژه برای نمایش داشبورد روی هر نمایشگر HD (1920x1080) ساخته شده است.

در مورد من، نیاز این بود که "شبیه" Skylight باشد، لمسی باشد، رومیزی باشد و امکان جابجایی به مکان‌های مختلف را داشته باشد. بنابراین با سخت‌افزار زیر پیش رفتم. با این حال، شرایط شما ممکن است متفاوت باشد و لازم است آن را بر اساس نیاز خود تنظیم کنید، مثلاً اگر بخواهید آن را روی یک تبلت یا دستگاه دیگر نمایش دهید.

سخت‌افزاری که در ابتدا انتخاب کردم بر اساس موارد بالا بود و همچنین با امید به گسترش قابلیت‌ها با استفاده از وب‌کم، اسپیکر و میکروفون. اکنون، با نگاه به گذشته، احتمالاً آن را متفاوت می‌ساختم، چون هنوز وقت نکرده‌ام به این ایده‌های سخت‌افزاری اضافه رسیدگی کنم.

✨ قابلیت‌ها

---

⚙️ راهنمای نصب

توجه: این راه‌اندازی از یک YAML Package استفاده می‌کند تا تمام دستیارها، اسکریپت‌ها و متغیرهای مورد نیاز را به طور خودکار برای شما ایجاد کند. نیازی به ساخت دستی آن‌ها ندارید.

۱. پیش‌نیازها (HACS)

شما باید HACS را نصب کرده باشید. لطفاً یکپارچه‌سازی‌های Frontend زیر را نصب کنید:

*توجه: در تنظیمات → دستگاه‌ها و سرویس‌ها مطمئن شوید Browser Mod به عنوان یک یکپارچه‌سازی (کاشی) ظاهر شده است و فقط زیر HACS نیست. اگر آنجا نیست، روی افزودن یکپارچه‌سازی → Browser Mod کلیک کرده و فرآیند را کامل کنید، سپس HA را ریستارت کنید. نصب از طریق HACS تنها فایل‌ها را دانلود می‌کند؛ باید یکپارچه‌سازی را اضافه کنید تا HA عملکردها/موجودیت‌های آن را ثبت کند.

۲. Backend (مغز سیستم)

   homeassistant:
     packages: !include_dir_named packages
   ``
  • یک پوشه به نام packages در دایرکتوری تنظیمات HA خود ایجاد کنید (اگر ندارید).
  • فایل packages/family_calendar.yaml را از این مخزن دانلود کنید.
  • عبارت [ #<--- UPDATE THIS ENTITY] را جستجو کرده و شناسه موجودیت تقویم را مطابق با محیط خود به‌روزرسانی کنید. برای جزئیات بیشتر بخش 3 را بررسی نمایید.
  • فایل را داخل پوشه packages/ قرار دهید.
  • Home Assistant را مجدداً راه‌اندازی کنید.

3. تقویم‌ها

می‌توانید از تقویم‌های گوگل یا تقویم‌های محلی استفاده کنید.

#### گزینه A: استفاده مجدد از نام‌های تقویم (آسان‌ترین)

  • به تنظیمات > دستگاه‌ها و سرویس‌ها بروید.
  • یکپارچه‌سازی تقویم محلی را اضافه کنید.
  • تقویم‌هایی با نام‌های دقیقاً: calendar1, calendar2, calendar3, calendar4, Family ایجاد کنید.
اگر از این نام‌ها استفاده کنید، کد به صورت آماده کار می‌کند!*

#### گزینه B: تقویم سفارشی

  • به تنظیمات > دستگاه‌ها و سرویس‌ها بروید.
  • یکپارچه‌سازی تقویم محلی یا تقویم گوگل را اضافه کنید.
  • به پیکربندی > یکپارچه‌سازی‌ها > تقویم محلی یا تقویم گوگل بروید و گزینه "افزودن ورودی" را انتخاب کنید.
  • برای هر ورودی ایجاد شده، شناسه موجودیت را برای به‌روزرسانی فایل dashboard.yaml دریافت کنید.
  • فایل dashboard.yaml را باز کنید.
  • عبارت # <--- UPDATE THIS ENTITY را جستجو کنید.
  • شناسه موجودیت را مطابق با محیط خود به‌روزرسانی کنید.
#### راه‌اندازی تعطیلات

با توجه به بروزرسانی‌های Home Assistant، تعطیلات اکنون از طریق رابط کاربری اضافه می‌شوند:

  • به تنظیمات > دستگاه‌ها و سرویس‌ها > افزودن یکپارچه‌سازی > تعطیلات بروید.
  • کشور خود را انتخاب کنید.
  • شناسه موجودیت را بررسی کنید (مثلاً calendar.holidays). اگر با مقدار پیش‌فرض تفاوت دارد، آن را در فایل dashboard YAML به‌روزرسانی کنید.

4. داشبورد (ظاهر)

  • به تنظیمات > داشبورد بروید
  • روی افزودن داشبورد کلیک کنید (گزینه "داشبورد جدید از ابتدا" را انتخاب کنید و مطمئن شوید که "افزودن به نوار کناری" را انتخاب کرده‌اید).
  • از منوی سمت چپ، داشبورد تازه ایجاد شده را انتخاب کرده و روی آیکون مداد برای ویرایش آن کلیک کنید.
  • روی آیکون سه نقطه کلیک کرده و "ویرایشگر پیکربندی خام" را انتخاب کنید.
  • کد را از dashboard.yaml کپی و جایگذاری کنید.

مرحله ۵: قالب (اختیاری)

برای دریافت ظاهر فونت خاص (Ovo):

  • اطمینان حاصل کنید که configuration.yaml شما این خط را زیر frontend: دارد
`yaml frontend: themes: !include_dir_merge_named themes `
  • یک پوشه به نام themes در دایرکتوری پیکربندی خود ایجاد کنید.
  • فایل themes/skylight.yaml را دانلود کرده و در آن پوشه قرار دهید.
  • با استفاده از File Editor فایل calbackgrd.png را در پوشه /www/ آپلود کنید که این پوشه به صورت داخلی در داشبورد به /local ترجمه می‌شود.
  • Home Assistant را ریستارت کنید.
  • به پروفایل خود بروید (آیکون کاربر پایین سمت چپ) و Theme را به Skylight تغییر دهید.
توجه: این تم کامل و جامع نیست، بنابراین این نکته را مد نظر داشته باشید.


📐 نحوه عملکرد (در پشت صحنه)

منطق فیلتر

کارت week-planner-card به طور ذاتی امکان پنهان کردن تقویم‌های خاص به صورت آنی را پشتیبانی نمی‌کند. برای حل این مشکل، من از Input Texts به عنوان فیلترهای Regex استفاده کردم.

وقتی روی دکمه یک شخص کلیک می‌کنید، فیلتر او بین مقدار . (نمایش همه چیز) و ^$ (عدم نمایش هیچ چیز) جابه‌جا می‌شود.

  • کارت config-template-card این متغیرها را به صورت پویا در کارت تقویم قرار می‌دهد.

اسکریپت ایجاد رویداد

پاپ‌آپ "افزودن رویداد" از یک اسکریپت واحد استفاده می‌کند که منطق مربوط به چندین نفر و انواع رویداد (تمام روز در مقابل زمان‌بندی شده) را مدیریت می‌کند.

yaml

Simplified Logic Example

target_calendar: "{{ calendar_map.get(states('input_select.calendar_select')) }}"

choose:

  • conditions: "All Day Event is ON"
action: calendar.create_event (start_date, end_date)
  • conditions: "All Day Event is OFF"
action: calendar.create_event (start_date_time, end_date_time)
``

یادداشت‌ها

پست اولیه من صرفاً برای ارائه یک نمای کلی از نحوه انجام این کار بود تا افراد بتوانند کد را مطابق نیاز خود تنظیم کنند.

به طور خاص من این کار را انجام دادم چون هر نمایشگر و نیازی متفاوت است. من نمی‌توانم برای همه اندازه‌های ممکن نمایشگرها، داشبوردها و غیره توسعه دهم. بنابراین این کد طوری ساخته شده که در نمایشگری که ذکر کردم یا هر نمایشگر دیگری (۱۹۲۰x۱۰۸۰) کار کند ولی باید برای سایر موارد قابل ویرایش باشد.

در مورد نمایشگر، من در ابتدا آن را پیشنهاد دادم چون آن زمان در سایت Woot با تخفیف فروخته می‌شد و یک روش اقتصادی برای تهیه نمایشگر لمسی بود. شاید اکنون اینطور نباشد، پس هر نمایشگری که برای شما مناسب است استفاده کنید. تبلت، صفحه لمسی، تلفن، هر چیزی. مورد اصلی که باید ویرایش کنید داشبورد است.

--- Tranlated By Open Ai Tx | Last indexed: 2026-03-08 ---