Skip to main content

Django utility wrapping dateutil.rrule

Project description

Jazzband GitHub PyPI release Supported Python versions Supported Django versions Documentation GitHub actions Coverage

django-recurrence is a utility for working with recurring dates in Django.

Functionality

  • Recurrence/Rule objects using a subset of rfc2445 (wraps dateutil.rrule) for specifying recurring date/times,

  • RecurrenceField for storing recurring datetimes in the database, and

  • JavaScript widget.

RecurrenceField provides a Django model field which serializes recurrence information for storage in the database.

For example - say you were storing information about a university course in your app. You could use a model like this:

import recurrence.fields

class Course(models.Model):
    title = models.CharField(max_length=200)
    start = models.TimeField()
    end = models.TimeField()
    recurrences = recurrence.fields.RecurrenceField()

You’ll notice that I’m storing my own start and end time. The recurrence field only deals with recurrences not with specific time information. I have an event that starts at 2pm. Its recurrences would be “every Friday”.

Documentation

For more information on installation and configuration see the documentation at:

https://django-recurrence.readthedocs.io/

Issues

If you have questions or have trouble using the app please file a bug report at:

https://github.com/jazzband/django-recurrence/issues

Contributions

All contributions are welcome!

It is best to separate proposed changes and PRs into small, distinct patches by type so that they can be merged faster into upstream and released quicker.

One way to organize contributions would be to separate PRs for e.g.

  • bugfixes,

  • new features,

  • code and design improvements,

  • documentation improvements, or

  • tooling and CI improvements.

Merging contributions requires passing the checks configured with the CI. This includes running tests and linters successfully on the currently officially supported Python and Django versions.

The test automation is run automatically with GitHub Actions, but you can run it locally with the tox command before pushing commits.

This is a Jazzband project. By contributing you agree to abide by the Contributor Code of Conduct and follow the guidelines.

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_recurrence-1.14.tar.gz (102.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_recurrence-1.14-py3-none-any.whl (135.7 kB view details)

Uploaded Python 3

File details

Details for the file django_recurrence-1.14.tar.gz.

File metadata

  • Download URL: django_recurrence-1.14.tar.gz
  • Upload date:
  • Size: 102.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for django_recurrence-1.14.tar.gz
Algorithm Hash digest
SHA256 154a6221bd6667c35250d9fa89bbc4792b3f1ec5dc8dff0f5872186b6df3cf76
MD5 2b2637af360823bf89fdf207e7c60a20
BLAKE2b-256 c490f083ae5fae92c121ed26689c21bba68cb4651defe62bdb70200ef47ece06

See more details on using hashes here.

File details

Details for the file django_recurrence-1.14-py3-none-any.whl.

File metadata

File hashes

Hashes for django_recurrence-1.14-py3-none-any.whl
Algorithm Hash digest
SHA256 3e7420a38c7fa2f5073598e2a4236c65a983213f30f4413618448b43514649cd
MD5 97de6a1cb44dcdb8f08e4614cd9781e9
BLAKE2b-256 8508fec7dd78259512152c75e8c64ac5ba389eef55569915b190f6b798f6ff7a

See more details on using hashes here.

Supported by

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