Mizu and Binki Calendar is a fun side project built in a day to help my family manage cat-sitting days. It includes an interactive React frontend and a simple Express server that sends friendly SMS reminders using Twilio. All bookings are stored in Firebase Realtime Database, ensuring everything stays up-to-date in real-time.
data:image/s3,"s3://crabby-images/a17c1/a17c114da833db0a928ba351fcfc0311fc815582" alt="image"
Schedule View with Color-Coded Bookings
- Interactive Calendar: Click on dates to see who’s booked or to confirm your own booking.
- Schedule View: Easily view all bookings with clear color indicators:
- Past Bookings: Greyed out.
- Next Upcoming Booking: Highlighted in green.
- Booking Modal: Simple form to confirm your booking.
- Checklist: Handy cat care checklist to keep track of tasks.
- Automated SMS Reminders: The server sends daily reminders to tomorrow’s cat sitter.
- Responsive Design: Looks great on both desktop and mobile devices.
- React with TypeScript
- Tailwind CSS for styling
- Headless UI for accessible components
- React Calendar for the calendar interface
- Firebase Realtime Database for storing bookings
- Node.js with Express
- Firebase Realtime Database for fetching booking data
- Node-Cron for scheduling daily tasks
- Twilio for sending SMS reminders
- dotenv for environment variable management
-
Booking a Date:
- Use the interactive calendar to select an available date.
- Confirm your booking by entering your name.
- The booking is saved to Firebase and immediately reflected in the Schedule View.
-
Viewing the Schedule:
- The Schedule View lists all bookings.
- Past bookings are greyed out, and the next upcoming booking is highlighted in green.
- Easily switch between Schedule and Calendar views with a toggle button.
-
Automated Reminders:
- The Express server runs a cron job every day at 9 AM Toronto time.
- It fetches the cat sitter scheduled for the next day from Firebase.
- If a valid phone number is found, Twilio sends a friendly SMS reminder to the sitter.
data:image/s3,"s3://crabby-images/6b64c/6b64c0b074f00218eefec5697f874fa1594361b9" alt="image"
Interactive Calendar for Booking Dates
data:image/s3,"s3://crabby-images/6c58e/6c58e890958ad5708b32f42f2c50670207aea7d0" alt="image"
Cat Care Checklist
- Not for Production: It’s a personal project, so feel free to fork and customize it as you like!
- Environment Variables: Make sure to set up your
.env
file with Firebase and Twilio credentials if you want to run the server locally.
This project is open-source and available under the MIT License.
Just a little project to keep our cat-sitting organized and ensure our furry friends are always looked after! 🐱💖