Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/michaeljohnbarr/django-timezone-utils
Time zone utilities for Django models.
https://github.com/michaeljohnbarr/django-timezone-utils
django python
Last synced: 2 months ago
JSON representation
Time zone utilities for Django models.
- Host: GitHub
- URL: https://github.com/michaeljohnbarr/django-timezone-utils
- Owner: michaeljohnbarr
- License: mit
- Created: 2015-02-05T03:46:01.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2022-02-15T12:26:18.000Z (almost 3 years ago)
- Last Synced: 2024-10-31T10:42:25.721Z (2 months ago)
- Topics: django, python
- Language: Python
- Size: 96.7 KB
- Stars: 29
- Watchers: 2
- Forks: 9
- Open Issues: 3
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
Django Timezone Utils: Time Zone Utilities For Models
=====================================================.. image:: https://img.shields.io/pypi/v/django-timezone-utils.svg?maxAge=2592000
:target: https://pypi.python.org/pypi/django-timezone-utils/
:alt: Latest Version.. image:: https://travis-ci.org/michaeljohnbarr/django-timezone-utils.png?branch=master
:target: https://travis-ci.org/michaeljohnbarr/django-timezone-utils
:alt: Test Status.. image:: https://coveralls.io/repos/michaeljohnbarr/django-timezone-utils/badge.svg
:target: https://coveralls.io/r/michaeljohnbarr/django-timezone-utils
:alt: Coverage Status.. image:: https://landscape.io/github/michaeljohnbarr/django-timezone-utils/master/landscape.png
:target: https://landscape.io/github/michaeljohnbarr/django-timezone-utils
:alt: Code Health.. image:: https://img.shields.io/pypi/pyversions/django-timezone-utils.svg?maxAge=2592000
:target: https://pypi.python.org/pypi/django-timezone-utils/
:alt: Supported Python versions.. image:: https://img.shields.io/pypi/l/django-timezone-utils.svg?maxAge=2592000
:target: https://pypi.python.org/pypi/django-timezone-utils/
:alt: License.. image:: https://img.shields.io/pypi/status/django-timezone-utils.svg?maxAge=2592000
:target: https://pypi.python.org/pypi/django-timezone-utils/
:alt: Development Status**django-timezone-utils** adds automatic time zone conversions and support
utilities to Django.Suggestions, constructive criticism, and feedback are certainly
welcomed and appreciated.Documentation
-------------Documentation for django-timezone-utils is available at `Read the Docs `_.
Inspiration
-----------On multiple occasions, I have had the need to store time zone information to the
one model, then base another model's datetime on that time zone. If you have
ever had to deal with this, you will know how complicated this can be.I created these fields to ease the process of manipulating times based on
another field's or models timezone choice. Instead of having to remember to use
``Model.clean``, we can now create the models with the validation built
into the model field.Quick Example
-------------.. code-block:: python
from datetime import datetime
from timezone_utils.fields import LinkedTZDateTimeField, TimeZoneField
from timezone_utils.choices import PRETTY_ALL_TIMEZONES_CHOICESclass Location(models.Model):
# ...
timezone = TimeZoneField(choices=PRETTY_ALL_TIMEZONES_CHOICES)def get_location_timezone(obj):
"""Returns the Location.timezone field from above"""return obj.location.timezone
class LocationReport(models.Model):
# ...
location = models.ForeignKey('app_label.Location', related_name='reports')# Populates from the Location.timezone
timestamp = LinkedTZDateTimeField(populate_from=get_location_timezone)class LocationPeriod(models.Model):
# ...
location = models.ForeignKey('app_label.Location', related_name='periods')# Sets the time to 12:00am in the location.timezone
start = LinkedTZDateTimeField(
populate_from=get_location_timezone,
time_override=datetime.min.time()
)# Sets the time to 11:59:59.99999pm in the location.timezone
end = LinkedTZDateTimeField(
populate_from=get_location_timezone,
time_override=datetime.max.time()
)Contributors
------------* `Michael Barr `_
* `Kosei Kitahara `_
* `Alex Kamedov `_
* `Pi Delport `_Changelog
---------
- 0.15.0 Add support for Django 4.0. Drop support for Django 1.11.
- 0.14.0 Add support for Django 2.2, 3.0. Drop support for Django 2.0, 2.1.
- 0.13 Fixed error for Python 3 on PyPi.
- 0.12 Add support for Django 2.1. Support Python 3.7. Drop support for Django 1.8.
- 0.11 Removed reference to django.db.models.fields.subclassing.SubfieldBase, which means that only Django 1.8+ is now supported. Removed support for Python versions < 2.6. The Django 1.6 series was the last to support Python 2.6. Added testing support for Django 1.10. Changed development status from Beta to Production/Stable.
- 0.10 Added testing support for Python 3.5 and Django 1.9.
- 0.9 Corrected a bug to where ``time_override`` caused invalid date due to not converting to the correct timezone first. Refactored conversion code. Added testing support for Django 1.8. Removed Django from setup requirements - the onus of having a supported version of Django is on the developer.
- 0.8 Corrected a bug to where ``time_override`` caused invalid date due to not converting to the correct timezone first. Added choices ``GROUPED_ALL_TIMEZONES_CHOICES`` and ``GROUPED_COMMON_TIMEZONES_CHOICES`` to the documentation.
- 0.7 Corrected a bug where datetime.max.time() resulted in incorrect date/time. Changed tests to compare time_override models via string to prevent future regressions. Added choices ``GROUPED_ALL_TIMEZONES_CHOICES`` and ``GROUPED_COMMON_TIMEZONES_CHOICES``.
- 0.6 Added RTD documentation. LinkedTZDateTimeField now returns the datetime object in the overidden timezone and time.
- 0.5 Bug fix: time override on datetime.min.time() failed to set time properly
- 0.4 Removed support for Python 2.5
- 0.3 Code cleanup.
- 0.2 Multiple bug fixes based on testing.
- 0.1 Initial release.