Skip to main content

Managing appointment scheduling with customizable slots, staff features, and conflict handling.

Project description

Django Appointment 📦

Tests Published on PyPi PyPI version codecov License GitHub commit activity GitHub last commit GitHub issues GitHub pull requests GitHub contributors

⚠️ IMPORTANT: If upgrading from a version before 2.x.x, please note significant database changes were introduced in Version 2.0.0 introduces significant database changes. Please read the migration guide before updating. No significant database changes were introduced in version 3.0.0.

Django-Appointment is a Django app engineered for managing appointment scheduling with ease and flexibility. It enables users to define custom configurations for time slots, lead time, and finish time, or utilize the default values provided. This app proficiently manages conflicts and availability for appointments, ensuring a seamless user experience.

For a detailed walkthrough and live example of the system, please refer to this tutorial.

Detailed documentation can be found in the docs' directory. For changes and migration information, please refer to the release notes.

Features ✨

  1. Customizable time slots, lead time, and finish time.
  2. Competent handling of appointment conflicts and availability.
  3. Seamless integration with the Django admin interface for appointment management.
  4. Custom admin interface for managing appointment/staff member editing, creation, availability, and conflicts.
  5. User-friendly interface for viewing available time slots and scheduling appointments.
  6. Capability to send email notifications to clients upon scheduling an appointment.

Key features introduced in previous versions.

Added Features in version 3.0.0

This release of Django Appointment brings a series of improvements and updates aimed at enhancing the overall functionality and user experience:

  1. Dynamic Appointment Management (#49, #55)

  2. User Interface Enhancements and JavaScript Refactoring (#55)

  3. Dynamic Label Customization in Appointment Pages (#19)

  4. Updated Documentation and Workflow Enhancements (#25, #26, #27)

  5. Community Engagement and Standards (#21, #22, #23, #24)

  6. Library Updates and Security Patches (#14, #15, #18)

  7. Enhanced Project Visibility (#16)

  8. Translation Refinements (#31)

  9. Bug Fixes (#48)

See more at the release notes.

These updates collectively contribute to the robustness and versatility of the Django Appointment package, aligning with our commitment to providing a high-quality and user-friendly appointment management solution.

Bug Fixes 🆕

See the release notes for more information.

Breaking Changes in version 3.0.0:

See the release notes for more information.

Quick Start 🚀

  1. Add "appointment" to your INSTALLED_APPS setting like so:

    INSTALLED_APPS = [
        # other apps
        'appointment',
    ]
    
  2. Incorporate the appointment URLconf in your project's urls.py like so:

    from django.urls import path, include
    
    urlpatterns = [
        # other urls
        path('appointment/', include('appointment.urls')),
    ]
    
  3. In your Django's settings.py, append the following:

    AUTH_USER_MODEL = 'models.UserModel'  # Optional if you use Django's user model
    

    For instance, if you employ a custom user model:

    AUTH_USER_MODEL = 'client.UserClient'
    

    If you're utilizing the default Django user model, there's no need to add this line since Django automatically sets it to:

    AUTH_USER_MODEL = 'auth.User'
    

    Ensure your create_user function includes the following arguments, even if they are not all utilized:

    def create_user(first_name, email, username, last_name=None, **extra_fields):
        pass
    

    This function will create a user with a password formatted as: f"{APPOINTMENT_WEBSITE_NAME}{current_year}"

    For instance, if you append this to your settings.py:

    APPOINTMENT_WEBSITE_NAME = 'Chocolates'
    

    And the current year is 2023, the password will be "Chocolates2023". If APPOINTMENT_WEBSITE_NAME is not provided, the default value is "Website", rendering the password as "Website2023".

    This name is also utilized in the footer of the emails sent to clients upon scheduling an appointment:

    <p>® 2023 {{ APPOINTMENT_WEBSITE_NAME }}. All Rights Reserved.</p>
    
  4. Execute python manage.py migrate to create the appointment models.

  5. Launch the development server and navigate to http://127.0.0.1:8000/admin/ to create appointments, manage configurations, and handle appointment conflicts (the Admin app must be enabled).

  6. You must create at least one service before using the application on the admin page. If your service is free, input 0 as the price. If your service is paid, input the price in the price field. You may also provide a description for your service.

  7. Visit http://127.0.0.1:8000/appointment/request/<service_id>/ to view the available time slots and schedule an appointment.

Customization 🔧

  1. In your Django project's settings.py, you can override the default values for the appointment scheduler. More information regarding available configurations can be found in the documentation.
  2. Modify these values as needed for your application, and the app will adapt to the new settings.
  3. For further customization, you can extend the provided models, views, and templates or create your own.

Support 💬

For support or inquiries regarding the Appointment Scheduler app, please refer to the documentation in the "docs" directory or visit the GitHub repository for more information.

Contributing 🤝

Contributions are welcome! Please refer to the contributing guidelines for more information.

Code of Conduct 📜

Please refer to the code of conduct for more information.

Security policy 🔒

Please refer to the security policy for more information.

Notes 📝⚠️

Currently, the application does not send email reminders yet. I'm also working on a testing website for the application that is not fully functional yet, no hard feelings. But you can check it out at https://django-appt.adamspierredavid.com/. Ideas are welcome here since I'm blocked on a few points.

About the Author

Adams Pierre David - Website

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-appointment-3.0.0.tar.gz (234.4 kB view hashes)

Uploaded Source

Built Distribution

django_appointment-3.0.0-py3-none-any.whl (269.8 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page