Skip to content

Commit 3dfbf45

Browse files
committed
Add all files - v1
1 parent df21f44 commit 3dfbf45

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

65 files changed

+2352
-1
lines changed

.gitignore

Lines changed: 96 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,96 @@
1+
# Text backup files
2+
*.bak
3+
4+
#Database
5+
*.sqlite3
6+
7+
8+
# Byte-compiled / optimized / DLL files
9+
__pycache__/
10+
*.py[cod]
11+
*$py.class
12+
13+
# C extensions
14+
*.so
15+
16+
# Distribution / packaging
17+
.Python
18+
env/
19+
build/
20+
develop-eggs/
21+
dist/
22+
downloads/
23+
eggs/
24+
.eggs/
25+
lib/
26+
lib64/
27+
parts/
28+
sdist/
29+
var/
30+
*.egg-info/
31+
.installed.cfg
32+
*.egg
33+
34+
# PyInstaller
35+
# Usually these files are written by a python script from a template
36+
# before PyInstaller builds the exe, so as to inject date/other infos into it.
37+
*.manifest
38+
*.spec
39+
40+
# Installer logs
41+
pip-log.txt
42+
pip-delete-this-directory.txt
43+
44+
# Unit test / coverage reports
45+
htmlcov/
46+
.tox/
47+
.coverage
48+
.coverage.*
49+
.cache
50+
nosetests.xml
51+
coverage.xml
52+
*,cover
53+
.hypothesis/
54+
55+
# Translations
56+
*.mo
57+
*.pot
58+
59+
# Django stuff:
60+
*.log
61+
local_settings.py
62+
63+
# Flask stuff:
64+
instance/
65+
.webassets-cache
66+
67+
# Scrapy stuff:
68+
.scrapy
69+
70+
# Sphinx documentation
71+
docs/_build/
72+
73+
# PyBuilder
74+
target/
75+
76+
# IPython Notebook
77+
.ipynb_checkpoints
78+
79+
# pyenv
80+
.python-version
81+
82+
# celery beat schedule file
83+
celerybeat-schedule
84+
85+
# dotenv
86+
.env
87+
88+
# virtualenv
89+
venv/
90+
ENV/
91+
92+
# Spyder project settings
93+
.spyderproject
94+
95+
# Rope project settings
96+
.ropeproject

LICENSE

Lines changed: 116 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,116 @@
1+
CC0 1.0 Universal
2+
3+
Statement of Purpose
4+
5+
The laws of most jurisdictions throughout the world automatically confer
6+
exclusive Copyright and Related Rights (defined below) upon the creator and
7+
subsequent owner(s) (each and all, an "owner") of an original work of
8+
authorship and/or a database (each, a "Work").
9+
10+
Certain owners wish to permanently relinquish those rights to a Work for the
11+
purpose of contributing to a commons of creative, cultural and scientific
12+
works ("Commons") that the public can reliably and without fear of later
13+
claims of infringement build upon, modify, incorporate in other works, reuse
14+
and redistribute as freely as possible in any form whatsoever and for any
15+
purposes, including without limitation commercial purposes. These owners may
16+
contribute to the Commons to promote the ideal of a free culture and the
17+
further production of creative, cultural and scientific works, or to gain
18+
reputation or greater distribution for their Work in part through the use and
19+
efforts of others.
20+
21+
For these and/or other purposes and motivations, and without any expectation
22+
of additional consideration or compensation, the person associating CC0 with a
23+
Work (the "Affirmer"), to the extent that he or she is an owner of Copyright
24+
and Related Rights in the Work, voluntarily elects to apply CC0 to the Work
25+
and publicly distribute the Work under its terms, with knowledge of his or her
26+
Copyright and Related Rights in the Work and the meaning and intended legal
27+
effect of CC0 on those rights.
28+
29+
1. Copyright and Related Rights. A Work made available under CC0 may be
30+
protected by copyright and related or neighboring rights ("Copyright and
31+
Related Rights"). Copyright and Related Rights include, but are not limited
32+
to, the following:
33+
34+
i. the right to reproduce, adapt, distribute, perform, display, communicate,
35+
and translate a Work;
36+
37+
ii. moral rights retained by the original author(s) and/or performer(s);
38+
39+
iii. publicity and privacy rights pertaining to a person's image or likeness
40+
depicted in a Work;
41+
42+
iv. rights protecting against unfair competition in regards to a Work,
43+
subject to the limitations in paragraph 4(a), below;
44+
45+
v. rights protecting the extraction, dissemination, use and reuse of data in
46+
a Work;
47+
48+
vi. database rights (such as those arising under Directive 96/9/EC of the
49+
European Parliament and of the Council of 11 March 1996 on the legal
50+
protection of databases, and under any national implementation thereof,
51+
including any amended or successor version of such directive); and
52+
53+
vii. other similar, equivalent or corresponding rights throughout the world
54+
based on applicable law or treaty, and any national implementations thereof.
55+
56+
2. Waiver. To the greatest extent permitted by, but not in contravention of,
57+
applicable law, Affirmer hereby overtly, fully, permanently, irrevocably and
58+
unconditionally waives, abandons, and surrenders all of Affirmer's Copyright
59+
and Related Rights and associated claims and causes of action, whether now
60+
known or unknown (including existing as well as future claims and causes of
61+
action), in the Work (i) in all territories worldwide, (ii) for the maximum
62+
duration provided by applicable law or treaty (including future time
63+
extensions), (iii) in any current or future medium and for any number of
64+
copies, and (iv) for any purpose whatsoever, including without limitation
65+
commercial, advertising or promotional purposes (the "Waiver"). Affirmer makes
66+
the Waiver for the benefit of each member of the public at large and to the
67+
detriment of Affirmer's heirs and successors, fully intending that such Waiver
68+
shall not be subject to revocation, rescission, cancellation, termination, or
69+
any other legal or equitable action to disrupt the quiet enjoyment of the Work
70+
by the public as contemplated by Affirmer's express Statement of Purpose.
71+
72+
3. Public License Fallback. Should any part of the Waiver for any reason be
73+
judged legally invalid or ineffective under applicable law, then the Waiver
74+
shall be preserved to the maximum extent permitted taking into account
75+
Affirmer's express Statement of Purpose. In addition, to the extent the Waiver
76+
is so judged Affirmer hereby grants to each affected person a royalty-free,
77+
non transferable, non sublicensable, non exclusive, irrevocable and
78+
unconditional license to exercise Affirmer's Copyright and Related Rights in
79+
the Work (i) in all territories worldwide, (ii) for the maximum duration
80+
provided by applicable law or treaty (including future time extensions), (iii)
81+
in any current or future medium and for any number of copies, and (iv) for any
82+
purpose whatsoever, including without limitation commercial, advertising or
83+
promotional purposes (the "License"). The License shall be deemed effective as
84+
of the date CC0 was applied by Affirmer to the Work. Should any part of the
85+
License for any reason be judged legally invalid or ineffective under
86+
applicable law, such partial invalidity or ineffectiveness shall not
87+
invalidate the remainder of the License, and in such case Affirmer hereby
88+
affirms that he or she will not (i) exercise any of his or her remaining
89+
Copyright and Related Rights in the Work or (ii) assert any associated claims
90+
and causes of action with respect to the Work, in either case contrary to
91+
Affirmer's express Statement of Purpose.
92+
93+
4. Limitations and Disclaimers.
94+
95+
a. No trademark or patent rights held by Affirmer are waived, abandoned,
96+
surrendered, licensed or otherwise affected by this document.
97+
98+
b. Affirmer offers the Work as-is and makes no representations or warranties
99+
of any kind concerning the Work, express, implied, statutory or otherwise,
100+
including without limitation warranties of title, merchantability, fitness
101+
for a particular purpose, non infringement, or the absence of latent or
102+
other defects, accuracy, or the present or absence of errors, whether or not
103+
discoverable, all to the greatest extent permissible under applicable law.
104+
105+
c. Affirmer disclaims responsibility for clearing rights of other persons
106+
that may apply to the Work or any use thereof, including without limitation
107+
any person's Copyright and Related Rights in the Work. Further, Affirmer
108+
disclaims responsibility for obtaining any necessary consents, permissions
109+
or other rights required for any use of the Work.
110+
111+
d. Affirmer understands and acknowledges that Creative Commons is not a
112+
party to this document and has no duty or obligation with respect to this
113+
CC0 or use of the Work.
114+
115+
For more information, please see
116+
<http://creativecommons.org/publicdomain/zero/1.0/>

Procfile

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
web: gunicorn locallibrary.wsgi --log-file -

README.md

Lines changed: 22 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1 +1,22 @@
1-
"# django-locallibrary-tutorial"
1+
# django_local_library
2+
Tutorial "Local Library" website written in Django.
3+
4+
----
5+
6+
This web application creates an online catalog for a small local library, where users can browse available books and manage their accounts.
7+
8+
The main features that have currently been implemented are:
9+
10+
* There are models for books, book copies, genre, language and authors.
11+
* Users can view list and detail information for books and authors.
12+
* Admin users can create and manage models. The admin has been optimised (the basic registration is present in admin.py, but commented out).
13+
* Librarians can renew reserved books
14+
15+
![](https://github.com/hamishwillee/django_local_library/blob/master/catalog/static/images/local_library_model_uml.png)
16+
17+
18+
19+
20+
21+
22+
For more information see the associated [MDN tutorial home page](https://developer.mozilla.org/en-US/docs/Learn/Server-side/Django/Tutorial_local_library_website).

catalog/__init__.py

Whitespace-only changes.

catalog/admin.py

Lines changed: 78 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,78 @@
1+
from django.contrib import admin
2+
3+
# Register your models here.
4+
5+
from .models import Author, Genre, Book, BookInstance, Language
6+
7+
"""
8+
# Minimal registration of Models.
9+
admin.site.register(Book)
10+
admin.site.register(Author)
11+
admin.site.register(BookInstance)
12+
admin.site.register(Genre)
13+
admin.site.register(Language)
14+
"""
15+
16+
admin.site.register(Genre)
17+
admin.site.register(Language)
18+
19+
class BooksInline(admin.TabularInline):
20+
"""
21+
Defines format of inline book insertion (used in AuthorAdmin)
22+
"""
23+
model = Book
24+
25+
26+
@admin.register(Author)
27+
class AuthorAdmin(admin.ModelAdmin):
28+
"""
29+
Administration object for Author models.
30+
Defines:
31+
- fields to be displayed in list view (list_display)
32+
- orders fields in detail view (fields), grouping the date fields horizontally
33+
- adds inline addition of books in author view (inlines)
34+
"""
35+
list_display = ('last_name', 'first_name', 'date_of_birth', 'date_of_death')
36+
fields = ['first_name', 'last_name', ('date_of_birth', 'date_of_death')]
37+
inlines = [BooksInline]
38+
39+
40+
class BooksInstanceInline(admin.TabularInline):
41+
"""
42+
Defines format of inline book instance insertion (used in BookAdmin)
43+
"""
44+
model = BookInstance
45+
46+
class BookAdmin(admin.ModelAdmin):
47+
"""
48+
Administration object for Book models.
49+
Defines:
50+
- fields to be displayed in list view (list_display)
51+
- adds inline addition of book instances in book view (inlines)
52+
"""
53+
list_display = ('title', 'author', 'display_genre')
54+
inlines = [BooksInstanceInline]
55+
56+
admin.site.register(Book, BookAdmin)
57+
58+
59+
@admin.register(BookInstance)
60+
class BookInstanceAdmin(admin.ModelAdmin):
61+
"""
62+
Administration object for BookInstance models.
63+
Defines:
64+
- fields to be displayed in list view (list_display)
65+
- filters that will be displayed in sidebar (list_filter)
66+
- grouping of fields into sections (fieldsets)
67+
"""
68+
list_display = ('book', 'status', 'borrower','due_back', 'id')
69+
list_filter = ('status', 'due_back')
70+
71+
fieldsets = (
72+
(None, {
73+
'fields': ('book','imprint', 'id')
74+
}),
75+
('Availability', {
76+
'fields': ('status', 'due_back','borrower')
77+
}),
78+
)

catalog/apps.py

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
from django.apps import AppConfig
2+
3+
4+
class CatalogConfig(AppConfig):
5+
name = 'catalog'

catalog/forms.py

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
from django.core.exceptions import ValidationError
2+
from django.utils.translation import ugettext_lazy as _
3+
import datetime #for checking renewal date range.
4+
5+
from django import forms
6+
7+
class RenewBookForm(forms.Form):
8+
"""
9+
Form for a librarian to renew books.
10+
"""
11+
renewal_date = forms.DateField(help_text="Enter a date between now and 4 weeks (default 3).")
12+
13+
def clean_renewal_date(self):
14+
data = self.cleaned_data['renewal_date']
15+
16+
#Check date is not in past.
17+
if data < datetime.date.today():
18+
raise ValidationError(_('Invalid date - renewal in past'))
19+
#Check date is in range librarian allowed to change (+4 weeks)
20+
if data > datetime.date.today() + datetime.timedelta(weeks=4):
21+
raise ValidationError(_('Invalid date - renewal more than 4 weeks ahead'))
22+
23+
# Remember to always return the cleaned data.
24+
return data

0 commit comments

Comments
 (0)