Skip to content

πŸŒπŸ•πŸ’€ A modern timezone comparison app that helps you compare time across different regions and countries.

License

Notifications You must be signed in to change notification settings

ziarahman/worldtimez

Repository files navigation

Worldtimez 🌍

License: MIT React TypeScript Material-UI

Worldtimez is a modern, user-friendly timezone comparison application built with React and Material-UI. It allows users to easily compare times across different timezones with an intuitive drag-and-drop interface.

✨ Features

  • πŸ•’ Compare multiple timezones simultaneously
  • πŸ“… Set specific date & time to compare
  • πŸ”„ Drag-and-drop interface for reordering timezones
  • πŸŒ“ Dark/Light mode support
  • πŸ“± Responsive design for all devices
  • πŸ” Smart timezone search with city suggestions
  • πŸ’Ύ Persistent storage of user preferences
  • ⚑ Fast and efficient time conversions

πŸš€ Setup

  1. Clone the repository:
git clone https://github.com/ziarahman/worldtimez.git
cd worldtimez
  1. Install dependencies:
npm install
  1. Copy .env.example to .env.local and fill in your API keys:
cp .env.example .env.local
  1. Start the development server:
npm run dev

πŸš€ Deployment

  1. Local Development

    • Copy .env.example to .env.local
    • Fill in your API keys in .env.local
    • Run npm run dev
  2. Production Deployment (Vercel)

    • Go to your Vercel project settings
    • Navigate to "Environment Variables"
    • Add the following variables:
      • VITE_GEODB_API_KEY
      • VITE_OPENCAGE_API_KEY
      • VITE_OPENWEATHER_API_KEY
      • VITE_TIMEZONEDB_API_KEY
    • Click "Deploy" to rebuild with new environment variables
  3. Managing Environment Variables and API Keys

    • Create a new file named .env in the root of your project
    • Add your API keys to the .env file, for example:
      • VITE_GEODB_API_KEY=YOUR_GEODB_API_KEY
      • VITE_OPENCAGE_API_KEY=YOUR_OPENCAGE_API_KEY
      • VITE_OPENWEATHER_API_KEY=YOUR_OPENWEATHER_API_KEY
      • VITE_TIMEZONEDB_API_KEY=YOUR_TIMEZONEDB_API_KEY
    • Make sure to add the .env file to your .gitignore file to avoid committing sensitive information

πŸš€ Getting Started

Prerequisites

  • Node.js (v18 or higher)
  • npm (v9 or higher)

Installation

  1. Clone the repository:
git clone https://github.com/ziarahman/worldtimez.git
cd worldtimez
  1. Install dependencies:
npm install
  1. Start the development server:
npm run dev
  1. Open http://localhost:4242 in your browser

πŸ—οΈ Production Deployment

Building for Production

  1. Create a production build:
npm run build
  1. Start the production server:
npm start

Docker Deployment

  1. Build the Docker image:
docker build -t worldtimez .
  1. Run the container:
docker run -p 4242:4242 worldtimez

πŸš€ Technologies

  • Frontend: React 18, TypeScript, Vite
  • UI Components: Material-UI (MUI)
  • State Management: Zustand
  • Date/Time Handling: Luxon
  • API Services:
    • GeoDB Cities API: For city data and geolocation
    • OpenCage Geocoding API: For geocoding and reverse geocoding
    • OpenWeatherMap API: For weather data and geolocation
    • TimezoneDB API: For timezone information
    • Nominatim API: For additional geocoding capabilities

πŸ› οΈ Tech Stack

πŸ“¦ Project Structure

worldtimez/
β”œβ”€β”€ src/
β”‚   β”œβ”€β”€ components/        # React components
β”‚   β”œβ”€β”€ data/             # Timezone data and utilities
β”‚   β”œβ”€β”€ lib/              # Helper functions
β”‚   β”œβ”€β”€ types/            # TypeScript type definitions
β”‚   β”œβ”€β”€ App.tsx           # Main application component
β”‚   └── main.tsx          # Application entry point
β”œβ”€β”€ public/               # Static assets
β”œβ”€β”€ server.js            # Production server
└── package.json         # Project dependencies

🀝 Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

πŸ“ License

This project is licensed under the MIT License - see the LICENSE file for details.

πŸ‘ Acknowledgments

πŸ”— Links


Made with ❀️ by Zia Rahman + Vibe Coding with AI πŸ€– using Windsurf.

About

πŸŒπŸ•πŸ’€ A modern timezone comparison app that helps you compare time across different regions and countries.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published