Date and time dependend content manipulation
Project description
Date and time dependent content manipulation.
Quick start
Install using pip:
pip install django-time-wizard
Make sure to follow the installation steps for django-polymorphic
Add to your INSTALLED_APPS:
'polymorphic', 'time_wizard',
Include the time_wizard admin URLs in your project urls.py:
path('admin/', include('time_wizard.urls')),
Run python manage.py migrate to create the time_wizard models.
Note
Upgrading from version 0.2.0 to 1.0.0 will delete all the created models of time_wizard!
Usage
You can use the TimeWizard in different ways:
use a ForeignKey-relation
use one TimeWizardModel-definition for as much models as you want
affects your database as the relation needs a new model field
example:
# models.py from time_wizard.mixins import TimeWizardMixin ... class MyModel(TimeWizardMixin, models.Model): ...
use the PeriodModelInline in the admin
each model of yours can have different time-settings
does not affect your database as it works with a generic relationship
example:
# models.py from time_wizard.mixins import TimeWizardInlineMixin ... class MyModel(TimeWizardInlineMixin, models.Model): ... # admin.py from time_wizard.admin import PeriodModelInline from polymorphic.admin import PolymorphicInlineSupportMixin ... class MyModelAdmin(PolymorphicInlineSupportMixin, admin.ModelAdmin): inlines = [PeriodModelInline] ...
in both ways use is_published on your model to indicate if the content is shown or not.
create a custom PeriodModel as a base for custom AbsoluteRange- and HolidayRange-models. There are abstract base classes defined in models/abstract.py. This means you could for example create classes without a generic relation, as PeriodModel itself has.
Settings
Django-time-wizard uses the defined countries and provinces/states from holidays. Definitions need to be compatible with holidays. You can also define this yourself for your needs:
TIME_WIZARD_COUNTRIES = ['US', 'UK', 'DE', ...] TIME_WIZARD_COUNTRY_PROVINCES = {'US': ['AL', 'AK', ...], ...}
Requirements
django
django-polymorphic
holidays
Tests
Setup your test environment with virtualenv and install the requirements with pip install .. Also install tox via pip and simply run tox.
Tests can also be run via devtools/run-tests. This requires an environment where docker and docker-compose are installed.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file django-time-wizard-3.0.2.tar.gz
.
File metadata
- Download URL: django-time-wizard-3.0.2.tar.gz
- Upload date:
- Size: 11.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 97a253b1adb91b62436df097620b7a2f71bd4d81138c8a9d7e7e7709ea012956 |
|
MD5 | bace1e1b94ef7cc355f54a6519f3235f |
|
BLAKE2b-256 | 19402c492ab2cd90f484168c2a4ea630e2076de65673ce8edc267787520de8ee |
File details
Details for the file django_time_wizard-3.0.2-py3-none-any.whl
.
File metadata
- Download URL: django_time_wizard-3.0.2-py3-none-any.whl
- Upload date:
- Size: 17.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 387612a6c6380890b31ad06ea5b9cb822e49eb037b10de6b2f39eae42d2d3dcd |
|
MD5 | 0223a39072e3de7e9855545c8c7210b0 |
|
BLAKE2b-256 | 4cb5573fac0bef7123722e15471c763fa9a7c84c03275d6dbf9e8f3315d3b9a7 |