summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--PythonTBC/settings.py2
-rwxr-xr-xbase.html428
-rw-r--r--requirements.txt2
-rw-r--r--tbc/certificate/tbc_certificate.tex6
-rw-r--r--tbc/forms.py2
-rw-r--r--tbc/models.py3
-rw-r--r--[-rwxr-xr-x]tbc/static/css/base.css0
-rw-r--r--[-rwxr-xr-x]tbc/static/css/responsive.css0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/.jshintrc0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-affix.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-alert.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-button.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-carousel.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-collapse.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-dropdown.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-modal.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-popover.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-scrollspy.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-tab.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-tooltip.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-transition.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/bootstrap-typeahead.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/jquery.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/index.html0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/phantom.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/server.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-affix.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-alert.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-button.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-carousel.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-collapse.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-dropdown.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-modal.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-phantom.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-popover.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-scrollspy.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-tab.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-tooltip.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-transition.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/unit/bootstrap-typeahead.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/vendor/jquery.js0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/vendor/qunit.css0
-rw-r--r--[-rwxr-xr-x]tbc/static/js/tests/vendor/qunit.js0
-rw-r--r--tbc/static/templates/editors-picks.html26
-rw-r--r--[-rwxr-xr-x]tbc/templates/base.html202
-rw-r--r--tbc/templates/tbc/aicte-books.html4
-rw-r--r--tbc/templates/tbc/book-details.html11
-rw-r--r--tbc/templates/tbc/book-review-details.html4
-rw-r--r--tbc/templates/tbc/book-review.html4
-rw-r--r--tbc/templates/tbc/books_under_progress.html2
-rw-r--r--tbc/templates/tbc/browse-books.html4
-rw-r--r--tbc/templates/tbc/completed_books.html2
-rw-r--r--tbc/templates/tbc/get-certificate.html2
-rw-r--r--tbc/templates/tbc/link_image.html2
-rw-r--r--[-rwxr-xr-x]tbc/templates/tbc/login.html4
-rw-r--r--tbc/templates/tbc/review-proposal.html12
-rw-r--r--tbc/urls.py91
-rw-r--r--[-rwxr-xr-x]tbc/views.py98
58 files changed, 751 insertions, 160 deletions
diff --git a/PythonTBC/settings.py b/PythonTBC/settings.py
index 4d99488..28eda1d 100644
--- a/PythonTBC/settings.py
+++ b/PythonTBC/settings.py
@@ -141,6 +141,8 @@ INSTALLED_APPS = (
'south',
'commentingapp',
'tbc_error_page',
+ 'taggit',
+ 'taggit_templatetags2',
)
diff --git a/base.html b/base.html
new file mode 100755
index 0000000..e47cbf6
--- /dev/null
+++ b/base.html
@@ -0,0 +1,428 @@
+{% load static %}
+{% load taggit_templatetags2_tags %}
+<!DOCTYPE html>
+<html lang="en">
+ <head>
+ <title>
+ {% block title %}
+ Python Textbook Companion Project | FOSSEE, IIT Bombay
+ {% endblock %}
+ </title>
+ {% block meta %}
+ <meta charset="utf-8">
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
+ <meta name="description" content="">
+ <meta name="author" content="">
+ {% endblock %}
+
+ <link rel="stylesheet" href="{% static 'css/bootstrap.min.css' %}" type="text/css" />
+ <link rel ="stylesheet" href="{% static 'css/responsive.css' %}" type="text/css"/>
+<style>
+.showonhover .hovertext { display: none;}
+.showonhover:hover .hovertext {display: inline;}
+a.viewdescription {color:#999;}
+a.viewdescription:hover {background-color:#999; color: White;}
+.hovertext {position:absolute;z-index:1000;border:1px solid #ffd971;background-color:#fffdce;padding:11px;width:250px;font-size: 0.75em;}
+</style>
+<style>
+ .module-list {
+ float: left;
+ height: 220px;
+ margin-top: 20px;
+ margin-bottom: 20px;
+ margin-left: 50px;
+ padding: 10px;
+ padding-bottom: 25px;
+ position: relative;
+ width: 300px;
+ background: #2c3e50;
+ }
+ .module-list img {
+ height: 220px;
+ }
+ .module-list img:hover{
+ height: 220px;
+ border-radius: 15px;
+ }
+
+ .module-list a{
+ color: #ffffff;
+ }
+ .navbar .container {
+ max-width: 1100px;
+ }
+ #content-wrap{
+ max-width: 1100px;
+ margin: 0 auto;
+ }
+ input[type="text"] {
+ width: 100%;
+ }
+ input[type="password"] {
+ width: 100%;
+ }
+ .gsc-search-button,
+ .gsc-clear-button {
+ position: relative;
+ top: -2px;
+ }
+ .badge-custom {
+ padding: 1.5px 7px 1.5px;
+ font-size: 12.025px;
+ font-weight: bold;
+ white-space: nowrap;
+ color: #ffffff;
+ background-color: #f89406;
+ -webkit-border-radius: 9px;
+ -moz-border-radius: 9px;
+ border-radius: 15px;
+ }
+
+ .tooltip-inner {
+ background-color: #1ABC9C;
+ width: 150px;
+ }
+
+ .tooltip.bottom .tooltip-arrow {
+ border-bottom: 5px solid #1ABC9C;
+ }
+ </style>
+<style>
+
+span.question {
+ cursor: pointer;
+ display: inline-block;
+ width: 20px;
+ height: 20px;
+ background-color: #89A4CC;
+ line-height: 16px;
+ color: White;
+ font-size: 13px;
+ font-weight: bold;
+ border-radius: 8px;
+ text-align: center;
+ position: relative;
+}
+span.question:hover { background-color: #3D6199; }
+
+ </style>
+ {% block css %}
+ <style type="text/css">
+ body {
+ padding-top: 60px;
+ padding-bottom: 40px;
+ }
+ </style>
+ {% endblock %}
+ </head>
+
+<body>
+<div class="navbar navbar navbar-fixed-top">
+ <div class="navbar-inner">
+ <div class="container">
+ <button type="button" class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
+ <span class="icon-bar"></span>
+ <span class="icon-bar"></span>
+ <span class="icon-bar"></span>
+ </button>
+ <a class="brand" href="/">Python Textbook Companion <sup><span style="font-size:12px; color: white;">beta</span></sup></a>
+ <div class="nav-collapse collapse">
+
+ <ul class="nav pull-right">
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle" data-toggle="dropdown">About<b class="caret"></b></a>
+ <ul class="dropdown-menu">
+ <li><a href="{% url 'tbc:AboutPytbc' %}">TBC Coding Guidelines</a></li>
+ <li><a href="http://fossee.in" target="_blank">FOSSEE</a></li>
+ <li><a href="http://python.fossee.in" target="_blank">Python Team</a></li>
+ </ul>
+ </li>
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle" data-toggle="dropdown">Textbooks<b class="caret"></b></a>
+ <ul class="dropdown-menu">
+ <li><a href="{% url 'tbc:CompletedBooks' %}">Completed Books</a></li>
+ <li><a href="{% url 'tbc:BooksUnderProgress' %}">Books Under Progress</a></li>
+ </ul>
+ </li>
+ <li><a href="{% url 'tbc:InternshipForms' %}">Internship Forms</a></li>
+
+ {% if user %}
+ {% if proposal_position %}
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle" data-toggle="dropdown">{{ user.first_name }}<span class="badge-custom" rel="tooltip" title="Pending Proposal Position: {{ proposal_position }}" data-placement="bottom" style="margin-left:5px; margin-right:5px; display: inline-block">{{ proposal_position }}</span>
+ <b class="caret"></b></a>
+ <ul class="dropdown-menu">
+ <li><a href="{% url 'tbc:SubmitBook' %}">Submit Book (OLD)</a></li>
+ <li><a href="{% url 'tbc:ListAICTE' %}">Submit Proposal</a></li>
+ <li><a href="{% url 'tbc:SubmitSample' %}">Submit Sample Notebook</a></li>
+ <li><a href="{% url 'tbc:ConfirmBookDetails' %}">Submit Codes</a></li>
+ <li><a href="{% url 'tbc:GetCertificate' %}">Get Certificate</a></li>
+ <li><a href="{% url 'tbc:UpdateProfile' %}">Update Profile</a></li>
+ <li><a href="{% url 'tbc:UpdatePassword' %}">Update Password</a></li>
+ <li><a href="{% url 'tbc:UserLogout' %}">Logout</a></li>
+ </ul>
+ </li>
+ {% else %}
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle" data-toggle="dropdown">{{ user.first_name }}<b class="caret"></b></a>
+ <ul class="dropdown-menu">
+ <li><a href="{% url 'tbc:SubmitBook' %}">Submit Book (OLD)</a></li>
+ <li><a href="{% url 'tbc:ListAICTE' %}">Submit Proposal</a></li>
+ <li><a href="{% url 'tbc:SubmitSample' %}">Submit Sample Notebook</a></li>
+ <li><a href="{% url 'tbc:ConfirmBookDetails' %}">Submit Codes</a></li>
+ <li><a href="{% url 'tbc:GetCertificate' %}">Get Certificate</a></li>
+ <li><a href="{% url 'tbc:UpdateProfile' %}">Update Profile</a></li>
+ <li><a href="{% url 'tbc:UpdatePassword' %}">Update Password</a></li>
+ <li><a href="{% url 'tbc:UserLogout' %}">Logout</a></li>
+ </ul>
+ </li>
+ {% endif %}
+ {% endif %}
+
+ {% if reviewer %}
+ <li class="dropdown">
+ <a href="#" class="dropdown-toggle" data-toggle="dropdown">{{ reviewer.first_name }} {{ reviewer.last_name }} <b class="caret"></b></a>
+ <ul class="dropdown-menu">
+ <li><a href="{% url 'tbc:BookReview' %}">Review Books</a></li>
+ <li><a href="{% url 'tbc:ReviewProposals' %}">Review Proposals</a></li>
+ <li><a href="{% url 'tbc:UserLogout' %}">Logout</a></li>
+ </ul>
+ </li>
+ {% endif %}
+
+ {% if anonymous %}
+ <li><a href="{% url 'tbc:UserLogin' %}">Login</a></li>
+ <li><a href="{% url 'tbc:UserRegister' %}">Sign Up</a></li>
+ {% endif %}
+
+ </ul> <!--/.nav -->
+ </div><!--/.nav-collapse -->
+ </div>
+ </div>
+ </div>
+ <div class="container">
+ {% block content %}
+ {% if up %}
+ <center>
+ <div class="alert" style="width:500px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>Book has been uploaded successfully !</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if login %}
+ <center>
+ <div class="alert" style="width:150px;height:23px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>Login Successful !</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if logout %}
+ <center>
+ <div class="alert" style="width:300px;height:23px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>You have logged out successfully !</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if update_book %}
+ <center>
+ <div class="alert" style="width:300px;height:23px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>Book has been updated successfully !</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if not_found %}
+ <center>
+ <div class="alert" style="width:650px;height:23px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>It seems that currently there is no book that you can update ! Please submit one.</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if proposal_submitted %}
+ <center>
+ <div class="alert" style="width:650px;height:40px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>Thank you for showing interest in contributing to Python TBC. <br>We have received your proposal. Please be patient we will get back to you within few days.</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if proposal_pending %}
+ <center>
+ <div class="alert" style="width:650px;height:40px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>You either have a proposal pending or you are already working on a book. You cannot submit a proposal at this moment.</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if book_pending %}
+ <center>
+ <div class="alert" style="width:650px;height:40px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>You either have a proposal pending or you are already working on a book. You cannot submit a proposal at this moment.</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if no_book_alloted %}
+ <center>
+ <div class="alert" style="width:400px;height:25px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>There is no book alloted to you. You cannot submit codes.</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if sample_notebook %}
+ <center>
+ <div class="alert" style="width:550px;height:40px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>Sample notebook has been submitted successfully. Please be patient while the reviewer reviews your codes & get backs to you.</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if cannot_submit_sample %}
+ <center>
+ <div class="alert" style="width:400px;height:25px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>You have not been permitted to send sample notebook.</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+ {% if bookupdate %}
+ <center>
+ <div class="alert" style="width:400px;height:25px;">
+ <a class="close" data-dismiss="alert" href="#">&times;</a>
+ <p>Thank You ! Codes have been updated successfully !</p>
+ </div>
+ </center>
+ <div class="clearfix"></div>
+ {% endif %}
+
+<div class="row-fluid">
+ <h3 style='float: left;margin-left: 50px; display: inline-block;'>Editors' Picks</h3>
+<div style="float:right; margin-right: 50px; width: 400px;"><gcse:search></gcse:search>
+ </div>
+<td>
+
+ <span class="showonhover">
+ <span class="question">?</span>
+ <span class="hovertext">
+ Minimum or NO trivial examples<br>
+ Maximum usage of scientific libraries
+ </span>
+ </span>
+</td>
+ {% get_taglist as tags for 'tbc.book' %}
+ <div style="clear:both;"></div>
+ {% for item in items %}
+ {% if item.book.tags.all %}
+<div class ="module-list">
+ <a href="{% url 'tbc:BookDetails' item.book.id %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ item.image.image }}"></a>
+ <center><a href="{% url 'tbc:BookDetails' item.book.id %}">{{ item.book.title }}</a></center>
+ </div>
+ {% endif %}
+ {% endfor %}
+
+
+</div>
+
+
+
+ <div class="row-fluid">
+ <h3 style='float: left;margin-left: 50px; display: inline-block;'>Recent Submissions</h3>
+ <div style="float:right; margin-right: 50px; width: 400px;">
+ <script>
+ (function() {
+ var cx = '001620609421546248003:nyipppxclkw';
+ var gcse = document.createElement('script');
+ gcse.type = 'text/javascript';
+ gcse.async = true;
+ gcse.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') +
+ '//www.google.com/cse/cse.js?cx=' + cx;
+ var s = document.getElementsByTagName('script')[0];
+ s.parentNode.insertBefore(gcse, s);
+ })();
+ </script>
+
+ </div>
+ <div style="clear:both;"></div>
+ {% for item in items|slice:":3" %}
+ <div class ="module-list">
+ <a href="{% url 'tbc:BookDetails' item.book.id %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ item.image.image }}"></a>
+ <center><a href="{% url 'tbc:BookDetails' item.book.id %}">{{ item.book.title }}</a></center>
+ </div>
+ {% endfor %}
+ </div>
+ <br>
+ <center>
+ <a class="btn btn-primary" href="{% url 'tbc:BrowseBooks' %}">Browse All Books</a>
+ </center>
+ <br>
+ <!--
+ <input type=text> <input type=submit value=Search>
+ -->
+
+
+ {% endblock %}
+ <hr>
+
+ <footer>
+ <center><p>&copy; FOSSEE - IIT Bombay 2014</p></center>
+ <center><img src="{% static 'images/fossee.png' %}" width=100 height=70><br><br>
+ <a rel="license" href="http://creativecommons.org/licenses/by-sa/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by-sa/4.0/88x31.png" /></a><br />This work is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by-sa/4.0/">Creative Commons Attribution-ShareAlike 4.0 International License</a>.</center>
+ </footer>
+
+ </div> <!-- /container -->
+
+ <script src="{% static 'js/jquery.js' %}"></script>
+ <script src="{% static 'js/bootstrap.min.js' %}"></script>
+ {% block script %}
+ {% endblock %}
+
+ <!-- google analytics -->
+ <script>
+ (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
+ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
+ m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
+ })(window,document,'script','//www.google-analytics.com/analytics.js','ga');
+
+ ga('create', 'UA-10406287-2', 'fossee.in');
+ ga('send', 'pageview');
+ </script>
+ <!-- / google analytics -->
+ <!-- Piwik -->
+<script type="text/javascript">
+ var _paq = _paq || [];
+ _paq.push(['trackPageView']);
+ _paq.push(['enableLinkTracking']);
+ (function() {
+ var u=(("https:" == document.location.protocol) ? "https" : "http") + "://analytics.spoken-tutorial.org/";
+ _paq.push(['setTrackerUrl', u+'piwik.php']);
+ _paq.push(['setSiteId', 15]);
+ var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0]; g.type='text/javascript';
+ g.defer=true; g.async=true; g.src=u+'piwik.js'; s.parentNode.insertBefore(g,s);
+ })();
+</script>
+<script type="text/javascript">
+ $(document).ready(function(){
+ $("[rel=tooltip]").tooltip();
+ });
+</script>
+<noscript><p><img src="http://analytics.spoken-tutorial.org/piwik.php?idsite=15" style="border:0;" alt="" /></p></noscript>
+<!-- End Piwik Code -->
+
+</body>
+</html>
diff --git a/requirements.txt b/requirements.txt
index 6e46e4a..ac72f30 100644
--- a/requirements.txt
+++ b/requirements.txt
@@ -12,3 +12,5 @@ requests==2.6.0
urllib3==1.10.2
wsgiref==0.1.2
scrapy==1.0.3
+django-taggit
+django-taggit-templatetags2
diff --git a/tbc/certificate/tbc_certificate.tex b/tbc/certificate/tbc_certificate.tex
new file mode 100644
index 0000000..06def58
--- /dev/null
+++ b/tbc/certificate/tbc_certificate.tex
@@ -0,0 +1,6 @@
+Certificate template for Python Textbook Companion
+Write your own template and use $variable name to substitute that variable
+with the data you want.
+Example use in the template and then using Template class of the string
+module you can substitute the with a name you want.
+Note: The template should result in a tex file.
diff --git a/tbc/forms.py b/tbc/forms.py
index 327c32a..f1a1328 100644
--- a/tbc/forms.py
+++ b/tbc/forms.py
@@ -62,7 +62,7 @@ class BookForm(forms.ModelForm):
self.fields['no_chapters'].label = "Number of Chapters"
class Meta:
model = Book
- exclude = ('contributor', 'approved', 'reviewer')
+ exclude = ('contributor', 'approved', 'reviewer', 'tags')
widgets = {
'title':forms.TextInput(attrs={'placeholder':'Title of the Book'}),
'author':forms.TextInput(attrs={'placeholder':'Author of the Book'}),
diff --git a/tbc/models.py b/tbc/models.py
index 4032125..44571ba 100644
--- a/tbc/models.py
+++ b/tbc/models.py
@@ -3,7 +3,7 @@ from django.contrib.auth.models import User
from PythonTBC import settings
from django.contrib.admin.models import LogEntry
from local import sitemap_path
-
+from taggit.managers import TaggableManager
CATEGORY = (("fluid mechanics", "Fluid Mechanics"),
("control systems", "Control Theory & Control Systems"),
@@ -104,6 +104,7 @@ class Book(models.Model):
contributor = models.ForeignKey(Profile)
reviewer = models.ForeignKey(Reviewer)
approved = models.BooleanField(default=False)
+ tags = TaggableManager()
def __unicode__(self):
name = self.title or 'Book'
return '%s'%(name)
diff --git a/tbc/static/css/base.css b/tbc/static/css/base.css
index c3d835e..c3d835e 100755..100644
--- a/tbc/static/css/base.css
+++ b/tbc/static/css/base.css
diff --git a/tbc/static/css/responsive.css b/tbc/static/css/responsive.css
index c0bba15..c0bba15 100755..100644
--- a/tbc/static/css/responsive.css
+++ b/tbc/static/css/responsive.css
diff --git a/tbc/static/js/.jshintrc b/tbc/static/js/.jshintrc
index e072269..e072269 100755..100644
--- a/tbc/static/js/.jshintrc
+++ b/tbc/static/js/.jshintrc
diff --git a/tbc/static/js/bootstrap-affix.js b/tbc/static/js/bootstrap-affix.js
index c1059a8..c1059a8 100755..100644
--- a/tbc/static/js/bootstrap-affix.js
+++ b/tbc/static/js/bootstrap-affix.js
diff --git a/tbc/static/js/bootstrap-alert.js b/tbc/static/js/bootstrap-alert.js
index 9577e62..9577e62 100755..100644
--- a/tbc/static/js/bootstrap-alert.js
+++ b/tbc/static/js/bootstrap-alert.js
diff --git a/tbc/static/js/bootstrap-button.js b/tbc/static/js/bootstrap-button.js
index 4b2a90a..4b2a90a 100755..100644
--- a/tbc/static/js/bootstrap-button.js
+++ b/tbc/static/js/bootstrap-button.js
diff --git a/tbc/static/js/bootstrap-carousel.js b/tbc/static/js/bootstrap-carousel.js
index c1e8ade..c1e8ade 100755..100644
--- a/tbc/static/js/bootstrap-carousel.js
+++ b/tbc/static/js/bootstrap-carousel.js
diff --git a/tbc/static/js/bootstrap-collapse.js b/tbc/static/js/bootstrap-collapse.js
index ae3e4c6..ae3e4c6 100755..100644
--- a/tbc/static/js/bootstrap-collapse.js
+++ b/tbc/static/js/bootstrap-collapse.js
diff --git a/tbc/static/js/bootstrap-dropdown.js b/tbc/static/js/bootstrap-dropdown.js
index d04da5d..d04da5d 100755..100644
--- a/tbc/static/js/bootstrap-dropdown.js
+++ b/tbc/static/js/bootstrap-dropdown.js
diff --git a/tbc/static/js/bootstrap-modal.js b/tbc/static/js/bootstrap-modal.js
index fb0b0db..fb0b0db 100755..100644
--- a/tbc/static/js/bootstrap-modal.js
+++ b/tbc/static/js/bootstrap-modal.js
diff --git a/tbc/static/js/bootstrap-popover.js b/tbc/static/js/bootstrap-popover.js
index 2b323b4..2b323b4 100755..100644
--- a/tbc/static/js/bootstrap-popover.js
+++ b/tbc/static/js/bootstrap-popover.js
diff --git a/tbc/static/js/bootstrap-scrollspy.js b/tbc/static/js/bootstrap-scrollspy.js
index 3ce5461..3ce5461 100755..100644
--- a/tbc/static/js/bootstrap-scrollspy.js
+++ b/tbc/static/js/bootstrap-scrollspy.js
diff --git a/tbc/static/js/bootstrap-tab.js b/tbc/static/js/bootstrap-tab.js
index 3a132c0..3a132c0 100755..100644
--- a/tbc/static/js/bootstrap-tab.js
+++ b/tbc/static/js/bootstrap-tab.js
diff --git a/tbc/static/js/bootstrap-tooltip.js b/tbc/static/js/bootstrap-tooltip.js
index acd6096..acd6096 100755..100644
--- a/tbc/static/js/bootstrap-tooltip.js
+++ b/tbc/static/js/bootstrap-tooltip.js
diff --git a/tbc/static/js/bootstrap-transition.js b/tbc/static/js/bootstrap-transition.js
index c4fd401..c4fd401 100755..100644
--- a/tbc/static/js/bootstrap-transition.js
+++ b/tbc/static/js/bootstrap-transition.js
diff --git a/tbc/static/js/bootstrap-typeahead.js b/tbc/static/js/bootstrap-typeahead.js
index 9cc84d8..9cc84d8 100755..100644
--- a/tbc/static/js/bootstrap-typeahead.js
+++ b/tbc/static/js/bootstrap-typeahead.js
diff --git a/tbc/static/js/jquery.js b/tbc/static/js/jquery.js
index 006e953..006e953 100755..100644
--- a/tbc/static/js/jquery.js
+++ b/tbc/static/js/jquery.js
diff --git a/tbc/static/js/tests/index.html b/tbc/static/js/tests/index.html
index 976ca16..976ca16 100755..100644
--- a/tbc/static/js/tests/index.html
+++ b/tbc/static/js/tests/index.html
diff --git a/tbc/static/js/tests/phantom.js b/tbc/static/js/tests/phantom.js
index 4105bf5..4105bf5 100755..100644
--- a/tbc/static/js/tests/phantom.js
+++ b/tbc/static/js/tests/phantom.js
diff --git a/tbc/static/js/tests/server.js b/tbc/static/js/tests/server.js
index 7c8445f..7c8445f 100755..100644
--- a/tbc/static/js/tests/server.js
+++ b/tbc/static/js/tests/server.js
diff --git a/tbc/static/js/tests/unit/bootstrap-affix.js b/tbc/static/js/tests/unit/bootstrap-affix.js
index c978878..c978878 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-affix.js
+++ b/tbc/static/js/tests/unit/bootstrap-affix.js
diff --git a/tbc/static/js/tests/unit/bootstrap-alert.js b/tbc/static/js/tests/unit/bootstrap-alert.js
index 9a6b514..9a6b514 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-alert.js
+++ b/tbc/static/js/tests/unit/bootstrap-alert.js
diff --git a/tbc/static/js/tests/unit/bootstrap-button.js b/tbc/static/js/tests/unit/bootstrap-button.js
index e23ff9e..e23ff9e 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-button.js
+++ b/tbc/static/js/tests/unit/bootstrap-button.js
diff --git a/tbc/static/js/tests/unit/bootstrap-carousel.js b/tbc/static/js/tests/unit/bootstrap-carousel.js
index 80b6e13..80b6e13 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-carousel.js
+++ b/tbc/static/js/tests/unit/bootstrap-carousel.js
diff --git a/tbc/static/js/tests/unit/bootstrap-collapse.js b/tbc/static/js/tests/unit/bootstrap-collapse.js
index 4c5916e..4c5916e 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-collapse.js
+++ b/tbc/static/js/tests/unit/bootstrap-collapse.js
diff --git a/tbc/static/js/tests/unit/bootstrap-dropdown.js b/tbc/static/js/tests/unit/bootstrap-dropdown.js
index 2f0d2d2..2f0d2d2 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-dropdown.js
+++ b/tbc/static/js/tests/unit/bootstrap-dropdown.js
diff --git a/tbc/static/js/tests/unit/bootstrap-modal.js b/tbc/static/js/tests/unit/bootstrap-modal.js
index b0096f8..b0096f8 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-modal.js
+++ b/tbc/static/js/tests/unit/bootstrap-modal.js
diff --git a/tbc/static/js/tests/unit/bootstrap-phantom.js b/tbc/static/js/tests/unit/bootstrap-phantom.js
index a04aeaa..a04aeaa 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-phantom.js
+++ b/tbc/static/js/tests/unit/bootstrap-phantom.js
diff --git a/tbc/static/js/tests/unit/bootstrap-popover.js b/tbc/static/js/tests/unit/bootstrap-popover.js
index 20234e1..20234e1 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-popover.js
+++ b/tbc/static/js/tests/unit/bootstrap-popover.js
diff --git a/tbc/static/js/tests/unit/bootstrap-scrollspy.js b/tbc/static/js/tests/unit/bootstrap-scrollspy.js
index 32bfa71..32bfa71 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-scrollspy.js
+++ b/tbc/static/js/tests/unit/bootstrap-scrollspy.js
diff --git a/tbc/static/js/tests/unit/bootstrap-tab.js b/tbc/static/js/tests/unit/bootstrap-tab.js
index ba5910d..ba5910d 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-tab.js
+++ b/tbc/static/js/tests/unit/bootstrap-tab.js
diff --git a/tbc/static/js/tests/unit/bootstrap-tooltip.js b/tbc/static/js/tests/unit/bootstrap-tooltip.js
index 5b37b4e..5b37b4e 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-tooltip.js
+++ b/tbc/static/js/tests/unit/bootstrap-tooltip.js
diff --git a/tbc/static/js/tests/unit/bootstrap-transition.js b/tbc/static/js/tests/unit/bootstrap-transition.js
index 086773f..086773f 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-transition.js
+++ b/tbc/static/js/tests/unit/bootstrap-transition.js
diff --git a/tbc/static/js/tests/unit/bootstrap-typeahead.js b/tbc/static/js/tests/unit/bootstrap-typeahead.js
index 0aa2d61..0aa2d61 100755..100644
--- a/tbc/static/js/tests/unit/bootstrap-typeahead.js
+++ b/tbc/static/js/tests/unit/bootstrap-typeahead.js
diff --git a/tbc/static/js/tests/vendor/jquery.js b/tbc/static/js/tests/vendor/jquery.js
index 006e953..006e953 100755..100644
--- a/tbc/static/js/tests/vendor/jquery.js
+++ b/tbc/static/js/tests/vendor/jquery.js
diff --git a/tbc/static/js/tests/vendor/qunit.css b/tbc/static/js/tests/vendor/qunit.css
index b3e3d00..b3e3d00 100755..100644
--- a/tbc/static/js/tests/vendor/qunit.css
+++ b/tbc/static/js/tests/vendor/qunit.css
diff --git a/tbc/static/js/tests/vendor/qunit.js b/tbc/static/js/tests/vendor/qunit.js
index 46c95b2..46c95b2 100755..100644
--- a/tbc/static/js/tests/vendor/qunit.js
+++ b/tbc/static/js/tests/vendor/qunit.js
diff --git a/tbc/static/templates/editors-picks.html b/tbc/static/templates/editors-picks.html
new file mode 100644
index 0000000..1406cf2
--- /dev/null
+++ b/tbc/static/templates/editors-picks.html
@@ -0,0 +1,26 @@
+<h4>Editors' Picks</h4>
+<p>
+ <ul>
+ <p>
+ <li>
+
+ <b> </b>Books with minimum or NO trivial examples
+
+ </li>
+<li>
+
+ <b> </b>Books with maximum usage of scientific libraries like Sympy
+
+ </li>
+<li>
+
+ <b> </b>Books with maximum usage of scientific libraries like Sympy
+
+ </li>
+<li>
+
+ <b> </b>Books with maximum functions and classes
+
+ </li>
+ </p>
+
diff --git a/tbc/templates/base.html b/tbc/templates/base.html
index 40812eb..645ceed 100755..100644
--- a/tbc/templates/base.html
+++ b/tbc/templates/base.html
@@ -1,4 +1,5 @@
{% load static %}
+{% load taggit_templatetags2_tags %}
<!DOCTYPE html>
<html lang="en">
<head>
@@ -16,7 +17,14 @@
<link rel="stylesheet" href="{% static 'css/bootstrap.min.css' %}" type="text/css" />
<link rel ="stylesheet" href="{% static 'css/responsive.css' %}" type="text/css"/>
- <style>
+<style>
+.showonhover .hovertext { display: none;}
+.showonhover:hover .hovertext {display: inline;}
+a.viewdescription {color:#999;}
+a.viewdescription:hover {background-color:#999; color: White;}
+.hovertext {position:absolute;z-index:1000;border:1px solid #ffd971;background-color:#fffdce;padding:11px;width:250px;font-size: 0.75em;}
+</style>
+<style>
.module-list {
float: left;
height: 220px;
@@ -56,7 +64,7 @@
.gsc-search-button,
.gsc-clear-button {
position: relative;
- top: -2px;
+ top: 2px;
}
.badge-custom {
padding: 1.5px 7px 1.5px;
@@ -79,14 +87,32 @@
border-bottom: 5px solid #1ABC9C;
}
</style>
+<style>
+
+ span.question {
+ cursor: pointer;
+ display: inline-block;
+ width: 20px;
+ height: 20px;
+ background-color: #89A4CC;
+ line-height: 16px;
+ color: White;
+ font-size: 13px;
+ font-weight: bold;
+ border-radius: 8px;
+ text-align: center;
+ position: relative;
+ }
+ span.question:hover { background-color: #3D6199; }
- {% block css %}
- <style type="text/css">
- body {
- padding-top: 60px;
- padding-bottom: 40px;
- }
- </style>
+ </style>
+ {% block css %}
+ <style type="text/css">
+ body {
+ padding-top: 60px;
+ padding-bottom: 40px;
+ }
+</style>
{% endblock %}
</head>
@@ -106,7 +132,7 @@
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">About<b class="caret"></b></a>
<ul class="dropdown-menu">
- <li><a href="{% url 'tbc:AboutPytbc' %}">TBC Coding Guidelines</a></li>
+
<li><a href="http://fossee.in" target="_blank">FOSSEE</a></li>
<li><a href="http://python.fossee.in" target="_blank">Python Team</a></li>
</ul>
@@ -114,11 +140,11 @@
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">Textbooks<b class="caret"></b></a>
<ul class="dropdown-menu">
- <li><a href="{% url 'tbc:CompletedBooks' %}">Completed Books</a></li>
- <li><a href="{% url 'tbc:BooksUnderProgress' %}">Books Under Progress</a></li>
+ <li><a href="{% url 'tbc:completed_books' %}">Completed Books</a></li>
+ <li><a href="{% url 'tbc:books_under_progress' %}">Books Under Progress</a></li>
</ul>
</li>
- <li><a href="{% url 'tbc:InternshipForms' %}">Internship Forms</a></li>
+ <li><a href="{% url 'tbc:internship_forms' %}">Internship Forms</a></li>
{% if user %}
{% if proposal_position %}
@@ -126,28 +152,28 @@
<a href="#" class="dropdown-toggle" data-toggle="dropdown">{{ user.first_name }}<span class="badge-custom" rel="tooltip" title="Pending Proposal Position: {{ proposal_position }}" data-placement="bottom" style="margin-left:5px; margin-right:5px; display: inline-block">{{ proposal_position }}</span>
<b class="caret"></b></a>
<ul class="dropdown-menu">
- <li><a href="{% url 'tbc:SubmitBook' %}">Submit Book (OLD)</a></li>
- <li><a href="{% url 'tbc:ListAICTE' %}">Submit Proposal</a></li>
- <li><a href="{% url 'tbc:SubmitSample' %}">Submit Sample Notebook</a></li>
- <li><a href="{% url 'tbc:ConfirmBookDetails' %}">Submit Codes</a></li>
- <li><a href="{% url 'tbc:GetCertificate' %}">Get Certificate</a></li>
- <li><a href="{% url 'tbc:UpdateProfile' %}">Update Profile</a></li>
- <li><a href="{% url 'tbc:UpdatePassword' %}">Update Password</a></li>
- <li><a href="{% url 'tbc:UserLogout' %}">Logout</a></li>
+ <li><a href="{% url 'tbc:submit_book' %}">Submit Book (OLD)</a></li>
+ <li><a href="{% url 'tbc:list_aicte' %}">Submit Proposal</a></li>
+ <li><a href="{% url 'tbc:submit_sample' %}">Submit Sample Notebook</a></li>
+ <li><a href="{% url 'tbc:confirm_book_details' %}">Submit Codes</a></li>
+ <li><a href="{% url 'tbc:get_certificate' %}">Get Certificate</a></li>
+ <li><a href="{% url 'tbc:update_profile' %}">Update Profile</a></li>
+ <li><a href="{% url 'tbc:update_password' %}">Update Password</a></li>
+ <li><a href="{% url 'tbc:user_logout' %}">Logout</a></li>
</ul>
</li>
{% else %}
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">{{ user.first_name }}<b class="caret"></b></a>
<ul class="dropdown-menu">
- <li><a href="{% url 'tbc:SubmitBook' %}">Submit Book (OLD)</a></li>
- <li><a href="{% url 'tbc:ListAICTE' %}">Submit Proposal</a></li>
- <li><a href="{% url 'tbc:SubmitSample' %}">Submit Sample Notebook</a></li>
- <li><a href="{% url 'tbc:ConfirmBookDetails' %}">Submit Codes</a></li>
- <li><a href="{% url 'tbc:GetCertificate' %}">Get Certificate</a></li>
- <li><a href="{% url 'tbc:UpdateProfile' %}">Update Profile</a></li>
- <li><a href="{% url 'tbc:UpdatePassword' %}">Update Password</a></li>
- <li><a href="{% url 'tbc:UserLogout' %}">Logout</a></li>
+ <li><a href="{% url 'tbc:submit_book' %}">Submit Book (OLD)</a></li>
+ <li><a href="{% url 'tbc:list_aicte' %}">Submit Proposal</a></li>
+ <li><a href="{% url 'tbc:submit_sample' %}">Submit Sample Notebook</a></li>
+ <li><a href="{% url 'tbc:confirm_book_details' %}">Submit Codes</a></li>
+ <li><a href="{% url 'tbc:get_certificate' %}">Get Certificate</a></li>
+ <li><a href="{% url 'tbc:update_profile' %}">Update Profile</a></li>
+ <li><a href="{% url 'tbc:update_password' %}">Update Password</a></li>
+ <li><a href="{% url 'tbc:user_logout' %}">Logout</a></li>
</ul>
</li>
{% endif %}
@@ -157,18 +183,17 @@
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">{{ reviewer.first_name }} {{ reviewer.last_name }} <b class="caret"></b></a>
<ul class="dropdown-menu">
- <li><a href="{% url 'tbc:BookReview' %}">Review Books</a></li>
- <li><a href="{% url 'tbc:ReviewProposals' %}">Review Proposals</a></li>
+ <li><a href="{% url 'tbc:book_review' %}">Review Books</a></li>
+ <li><a href="{% url 'tbc:review_proposals' %}">Review Proposals</a></li>
<li><a href="{% url 'tbc:admin_tools' %}">Admin Tools </a></li>
- <li><a href="{% url 'tbc:UserLogout' %}">Logout</a></li>
-
+ <li><a href="{% url 'tbc:user_logout' %}">Logout</a></li>
</ul>
</li>
{% endif %}
{% if anonymous %}
- <li><a href="{% url 'tbc:UserLogin' %}">Login</a></li>
- <li><a href="{% url 'tbc:UserRegister' %}">Sign Up</a></li>
+ <li><a href="{% url 'tbc:user_login' %}">Login</a></li>
+ <li><a href="{% url 'tbc:user_register' %}">Sign Up</a></li>
{% endif %}
</ul> <!--/.nav -->
@@ -286,6 +311,101 @@
</center>
<div class="clearfix"></div>
{% endif %}
+<div style="float:right; margin-right: 50px; width: 400px;"><gcse:search></gcse:search>
+ </div>
+ <script src="http://code.jquery.com/jquery-1.4.min.js" type="text/javascript"></script>
+ <script type="text/javascript">
+ $(document).ready(function(){
+
+ $("#objective").click(function(){
+ $('#details').load('{% static "templates/objectives.html" %}');
+ });
+
+
+ $("#who").click(function(){
+ $('#details').load('{% static "templates/who.html" %}');
+ });
+
+ $("#how").click(function(){
+ $('#details').load('{% static "templates/how.html" %}');
+ });
+
+ $("#guidelines").click(function(){
+ $('#details').load('{% static "templates/guidelines.html" %}');
+ });
+
+ $("#goodies").click(function(){
+ $('#details').load('{% static "templates/goodie.html" %}');
+ });
+
+ $("#disclaimer").click(function(){
+ $('#details').load('{% static "templates/disclaimer.html" %}');
+ });
+
+ $("#faqs").click(function(){
+ $('#details').load('{% static "templates/faq.html" %}');
+ });
+
+ $("#contact").click(function(){
+ $('#details').load('{% static "templates/contactus.html" %}');
+ });
+ });
+ </script>
+
+
+ <div class="well span3" style="width:18%;margin-left:5px;margin-top:60px;">
+ <div class="nav nav-list">
+ <ul>
+ <li><a id="objective" href="#"><strong>Objective</strong></a></li>
+ <li><a id="who" href="#"><strong>Who can contribute ?</strong></a></li>
+ <li><a id="how" href="#"><strong>How to contribute ?</strong></a></li>
+ <li><a id="guidelines" href="#"><strong>Guidelines for Coding</strong></a></li>
+ <li><a id="goodies" href="#"><strong>Goodies</strong></a></li>
+ <li><a id="disclaimer" href="#"><strong>Disclaimer</strong></a></li>
+ <li><a id="faqs" href="#"><strong>FAQs</strong></a></li>
+ <li><a id="contact" href="#"><strong>Contact</strong></a></li>
+ </ul>
+ </div>
+ </div>
+ <div class="well span9" id="details" style="float:right;width:74%;margin-left:5px;min-height:150px;">
+ <p>The Textbook Companion activity aims to create a repository of reference material for Python by coding solved examples of standard engineering textbooks using Python. This activity intends to,</p>
+ <ul>
+ <li>Make individuals learn Python through a practical approach</li>
+ <li>Provide a huge database of Companions as a learning resource</li>
+ <li>To make it easy for users of such textbooks to start using Python.</li>
+ <li>To improve the documentation available for Python</li>
+ </ul>
+ </div>
+</div>
+
+<div class="row-fluid">
+ <h3 style='float: left;margin-left: 50px; display: inline-block;'>Editors' Picks</h3>
+
+<td>
+
+ <span class="showonhover">
+ <span class="question">?</span>
+ <span class="hovertext">
+ Books with maximum usage of scientific libraries
+ </span>
+ </span>
+</td>
+ {% get_taglist as tags for 'tbc.book' %}
+ <div style="clear:both;"></div>
+ {% for item in items %}
+ {% if item.book.tags.all %}
+<div class ="module-list">
+ <a href="{% url 'tbc:book_details' item.book.id %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ item.image.image }}"></a>
+ <center><a href="{% url 'tbc:book_details' item.book.id %}">{{ item.book.title }}</a></center>
+ </div>
+ {% endif %}
+ {% endfor %}
+
+
+</div>
+
+
+
<div class="row-fluid">
<h3 style='float: left;margin-left: 50px; display: inline-block;'>Recent Submissions</h3>
<div style="float:right; margin-right: 50px; width: 400px;">
@@ -301,24 +421,26 @@
s.parentNode.insertBefore(gcse, s);
})();
</script>
- <gcse:search></gcse:search>
+
</div>
<div style="clear:both;"></div>
- {% for item in items %}
+ {% for item in items|slice:":3" %}
<div class ="module-list">
- <a href="{% url 'tbc:BookDetails' item.book.id %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ item.image.image }}"></a>
- <center><a href="{% url 'tbc:BookDetails' item.book.id %}">{{ item.book.title }}</a></center>
+ <a href="{% url 'tbc:book_details' item.book.id %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ item.image.image }}"></a>
+ <center><a href="{% url 'tbc:book_details' item.book.id %}">{{ item.book.title }}</a></center>
</div>
{% endfor %}
</div>
<br>
<center>
- <a class="btn btn-primary" href="{% url 'tbc:BrowseBooks' %}">Browse All Books</a>
+ <a class="btn btn-primary" href="{% url 'tbc:browse_books' %}">Browse All Books</a>
</center>
<br>
<!--
<input type=text> <input type=submit value=Search>
-->
+
+
{% endblock %}
<hr>
diff --git a/tbc/templates/tbc/aicte-books.html b/tbc/templates/tbc/aicte-books.html
index a15d686..eb68e2b 100644
--- a/tbc/templates/tbc/aicte-books.html
+++ b/tbc/templates/tbc/aicte-books.html
@@ -16,7 +16,7 @@ function submitCategory()
<hr>
<div id="content-wrap">
<p>Below is the list of AICTE recommended books. You can propose a book just by clicking on the link. However, if you wish to submit your own preferences other than AICTE books, click the button given below.</p>
- <a href="{% url 'tbc:SubmitProposal' %}" class="btn btn-primary">I don't want to propose AICTE book</a>
+ <a href="{% url 'tbc:submit_proposal' %}" class="btn btn-primary">I don't want to propose AICTE book</a>
<hr>
<center><h4>Select a Category</h4></center>
<form name="aictebooks" action="/submit-aicte-proposal/" method=POST enctype="multipart/form-data">
@@ -52,7 +52,7 @@ function submitCategory()
{{ forloop.counter }}
</td>
<td>
- <a href="{% url 'tbc:SubmitAICTEProposal' book.id %}">{{ book.title }} by {{ book.author }}, {{ book.edition }} Edition</a>
+ <a href="{% url 'tbc:submit_aicte_proposal' book.id %}">{{ book.title }} by {{ book.author }}, {{ book.edition }} Edition</a>
</td>
</tr>
{% endfor %}
diff --git a/tbc/templates/tbc/book-details.html b/tbc/templates/tbc/book-details.html
index b161c76..fc67847 100644
--- a/tbc/templates/tbc/book-details.html
+++ b/tbc/templates/tbc/book-details.html
@@ -20,7 +20,7 @@ function redirectToIpynb(notebook)
{% for image in images %}
<div class ="module-list">
{% if image.chapters_set.get.notebook %}
- <a href="{% url 'tbc:ConvertNotebook' image.chapters_set.get.notebook %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ image.image }}"></a>
+ <a href="{% url 'tbc:convert_notebook' image.chapters_set.get.notebook %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ image.image }}"></a>
{% else %}
<img src="{% static 'Python-Textbook-Companions/' %}{{ image.image }}">
{% endif %}
@@ -36,7 +36,7 @@ function redirectToIpynb(notebook)
{% for chapter in chapters %}
<tr>
<td>
- <a href="{% url 'tbc:ConvertNotebook' chapter.notebook %}">{{ chapter.name }}</a>
+ <a href="{% url 'tbc:convert_notebook' chapter.notebook %}">{{ chapter.name }}</a>
</td>
<td>
<a href="{% static 'uploads/' %}{{ chapter.notebook }}">Download</a>
@@ -45,7 +45,7 @@ function redirectToIpynb(notebook)
{% endfor %}
</table>
<hr>
-<a class="btn btn-primary btn-large" href="{% url 'tbc:GetZip' book.id %}" style="float:right; margin-top:20px;">Download Book as Zip</a>
+<a class="btn btn-primary btn-large" href="{% url 'tbc:get_zip' book.id %}" style="float:right; margin-top:20px;">Download Book as Zip</a>
<table>
<tr>
<td>Author: &nbsp;&nbsp;</td>
@@ -57,7 +57,7 @@ function redirectToIpynb(notebook)
</tr>
<tr>
<td>ISBN: &nbsp;&nbsp;</td>
- <td><a href= http://www.isbnsearch.org/isbn/{{book.isbn}} target="_blank">{{book.isbn }}</a></td>
+ <td><a href= http://www.isbnsearch.org/isbn/{{ book.isbn }} target="_blank">{{ book.isbn }}</a></td>
</tr>
<tr>
<td>Contributor: &nbsp;&nbsp;</td>
@@ -77,8 +77,9 @@ function redirectToIpynb(notebook)
</tr>
<tr>
<td>GitHub: &nbsp;&nbsp;</td>
- <td><a href= 'https://github.com/FOSSEE/Python-Textbook-Companions/tree/master/{{book.title.split|join:"_"}}_by_{{book.author.split|join:"_"}}' target="_blank">{{book.title}}</a></td>
+ <td><a href= 'https://github.com/FOSSEE/Python-Textbook-Companions/tree/master/{{ book.title.split|join:"_" }}_by_{{ book.author.split|join:"_" }}' target="_blank">{{ book.title }}</a></td>
</tr>
+
</table>
</div>
diff --git a/tbc/templates/tbc/book-review-details.html b/tbc/templates/tbc/book-review-details.html
index 33401d5..26bf85f 100644
--- a/tbc/templates/tbc/book-review-details.html
+++ b/tbc/templates/tbc/book-review-details.html
@@ -6,7 +6,7 @@
{% for image in images %}
<div class ="module-list">
{% if image.chapters_set.get.notebook %}
- <a href="{% url 'tbc:ConvertNotebook' image.chapters_set.get.notebook %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ image.image }}"></a>
+ <a href="{% url 'tbc:convert_notebook' image.chapters_set.get.notebook %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ image.image }}"></a>
{% else %}
<img src="{% static 'Python-Textbook-Companions/' %}{{ image.image }}">
{% endif %}
@@ -18,7 +18,7 @@
<table class="table table-bordered table-hover">
{% for chapter in chapters %}
<tr>
- <td><a href="{% url 'tbc:ConvertNotebook' chapter.notebook %}">{{ chapter.name }}</a></td>
+ <td><a href="{% url 'tbc:convert_notebook' chapter.notebook %}">{{ chapter.name }}</a></td>
</tr>
{% endfor %}
</table>
diff --git a/tbc/templates/tbc/book-review.html b/tbc/templates/tbc/book-review.html
index 7bb88ff..f26c7ba 100644
--- a/tbc/templates/tbc/book-review.html
+++ b/tbc/templates/tbc/book-review.html
@@ -20,13 +20,13 @@
<center><h3>Books to be reviewed</h3></center>
<ol>
{% for book in books %}
- <li><a href="{% url 'tbc:BookReview' book.id %}">{{ book.title }} {{ book.edition }} Edition</a>
+ <li><a href="{% url 'tbc:book_review' book.id %}">{{ book.title }} {{ book.edition }} Edition</a>
{% endfor %}
</ol>
<center><h3>Reviewed Books</h3></center>
<ol>
{% for book in approved_books %}
-<li><a href="{% url 'tbc:BookReview' book.id %}">{{ book.title }} {{ book.edition }} Edition</a></li>
+<li><a href="{% url 'tbc:book_review' book.id %}">{{ book.title }} {{ book.edition }} Edition</a></li>
{% endfor %}
<ol>
{% endblock %}
diff --git a/tbc/templates/tbc/books_under_progress.html b/tbc/templates/tbc/books_under_progress.html
index 494214b..90803ec 100644
--- a/tbc/templates/tbc/books_under_progress.html
+++ b/tbc/templates/tbc/books_under_progress.html
@@ -44,7 +44,7 @@ function submitCategory()
{{ forloop.counter }}
</td>
<td>
- <a href="{% url 'tbc:BookDetails' book.id %}">{{ book.title }} by {{ book.author }}</a>
+ <a href="{% url 'tbc:book_details' book.id %}">{{ book.title }} by {{ book.author }}</a>
</td>
</tr>
{% endfor %}
diff --git a/tbc/templates/tbc/browse-books.html b/tbc/templates/tbc/browse-books.html
index 1c20ea5..31929b1 100644
--- a/tbc/templates/tbc/browse-books.html
+++ b/tbc/templates/tbc/browse-books.html
@@ -34,8 +34,8 @@ function submitCategory()
<div class="row-fluid">
{% for item in items %}
<div class ="module-list">
- <a href="{% url 'tbc:BookDetails' item.book.id %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ item.image.image }}"></a>
- <center><a href="{% url 'tbc:BookDetails' item.book.id %}">{{ item.book.title }}</a></center>
+ <a href="{% url 'tbc:book_details' item.book.id %}"><img src="{% static 'Python-Textbook-Companions/' %}{{ item.image.image }}"></a>
+ <center><a href="{% url 'tbc:book_details' item.book.id %}">{{ item.book.title }}</a></center>
</div>
{% endfor %}
</div>
diff --git a/tbc/templates/tbc/completed_books.html b/tbc/templates/tbc/completed_books.html
index 11bdeb0..44acdc9 100644
--- a/tbc/templates/tbc/completed_books.html
+++ b/tbc/templates/tbc/completed_books.html
@@ -42,7 +42,7 @@ function submitCategory()
{{ forloop.counter }}
</td>
<td>
- <a href="{% url 'tbc:BookDetails' book.id %}">{{ book.title }} by {{ book.author }}</a>
+ <a href="{% url 'tbc:book_details' book.id %}">{{ book.title }} by {{ book.author }}</a>
</td>
</tr>
{% endfor %}
diff --git a/tbc/templates/tbc/get-certificate.html b/tbc/templates/tbc/get-certificate.html
index 6b6b622..5273efa 100644
--- a/tbc/templates/tbc/get-certificate.html
+++ b/tbc/templates/tbc/get-certificate.html
@@ -16,7 +16,7 @@
{{ book.title }} by {{ book.author }}, {{ book.edition }} Edition
</td>
<td>
- <a class="btn btn-primary" href="{% url 'tbc:GetCertificate' book.id %}">Get Certificate</a>
+ <a class="btn btn-primary" href="{% url 'tbc:get_certificate' book.id %}">Get Certificate</a>
</td>
</tr>
{% endfor %}
diff --git a/tbc/templates/tbc/link_image.html b/tbc/templates/tbc/link_image.html
index 03cdcec..35d55d5 100644
--- a/tbc/templates/tbc/link_image.html
+++ b/tbc/templates/tbc/link_image.html
@@ -37,7 +37,7 @@
<b><u> Below are the links to the chapters:</u></b><br>
{% for chapter in chapters %}
- <a href="{% url 'tbc:ConvertNotebook' chapter.notebook %}" target="_blank">{{ chapter }}</a>
+ <a href="{% url 'tbc:convert_notebook' chapter.notebook %}" target="_blank">{{ chapter }}</a>
<br>
{% endfor %}
</div>
diff --git a/tbc/templates/tbc/login.html b/tbc/templates/tbc/login.html
index fc71732..74c6405 100755..100644
--- a/tbc/templates/tbc/login.html
+++ b/tbc/templates/tbc/login.html
@@ -70,8 +70,8 @@
{% csrf_token %}
{{ form.as_p }}
<input class="btn btn-primary"type=submit value=Login>
- <a href="{% url 'tbc:UserRegister' %}" class="btn btn-primary">Sign Up</a>
- <a href="{% url 'tbc:ForgotPassword' %}" class="btn btn-primary">Forgot Password</a>
+ <a href="{% url 'tbc:user_register' %}" class="btn btn-primary">Sign Up</a>
+ <a href="{% url 'tbc:forgot_password' %}" class="btn btn-primary">Forgot Password</a>
</form>
</div>
{% endblock %}
diff --git a/tbc/templates/tbc/review-proposal.html b/tbc/templates/tbc/review-proposal.html
index 2499b45..f8b67e0 100644
--- a/tbc/templates/tbc/review-proposal.html
+++ b/tbc/templates/tbc/review-proposal.html
@@ -25,13 +25,13 @@
ISBN: {{ textbook.isbn }}<br>
Year of Pub.: {{ textbook.year_of_pub }}<br>
Category: {{ textbook.category }}<br>
- <a class="btn btn-primary btn-mini" href="{% url 'tbc:ReviewProposals' proposal.id textbook.id %}">Approve & Ask for Samples</a>
+ <a class="btn btn-primary btn-mini" href="{% url 'tbc:review_proposals' proposal.id textbook.id %}">Approve & Ask for Samples</a>
</div>
</div>
</div>
{% endfor %}
<h5><b>Status:</b> You are yet to review this proposal</h5>
- <a class="btn btn-primary" href="{% url 'tbc:RejectProposal' proposal.id %}">Reject</a>
+ <a class="btn btn-primary" href="{% url 'tbc:reject_proposal' proposal.id %}">Reject</a>
</div>
{% endfor %}
</ol>
@@ -71,8 +71,8 @@
{% ifequal proposal.proposal.status "sample resubmitted" %}
{% if proposal.sample.sample_notebook %}
<h5><a href="{% static 'Python-Textbook-Companions/' %}{{ proposal.sample.sample_notebook }}">sample notebook</a><br></h5>
- <a class="btn btn-primary" href="{% url 'tbc:DisapproveProposal' proposal.proposal.id %}">Disapprove Samples</a>
- <a class="btn btn-primary" href="{% url 'tbc:AllotBook' proposal.proposal.id %}">Alot Book</a>
+ <a class="btn btn-primary" href="{% url 'tbc:disapprove_proposal' proposal.proposal.id %}">Disapprove Samples</a>
+ <a class="btn btn-primary" href="{% url 'tbc:allot_book' proposal.proposal.id %}">Alot Book</a>
<h5>This is resubmission of the sample notebook</h5>
{% else %}
<h5>Contributor has not re submitted sample notebook yet.</h5>
@@ -81,8 +81,8 @@
{% ifequal proposal.proposal.status "sample submitted" %}
{% if proposal.sample.sample_notebook %}
<h5><a href="{% static 'Python-Textbook-Companions/' %}{{ proposal.sample.sample_notebook }}">sample notebook</a><br></h5>
- <a class="btn btn-primary" href="{% url 'tbc:DisapproveProposal' proposal.proposal.id %}">Disapprove Samples</a>
- <a class="btn btn-primary" href="{% url 'tbc:AllotBook' proposal.proposal.id %}">Alot Book</a>
+ <a class="btn btn-primary" href="{% url 'tbc:disapprove_proposal' proposal.proposal.id %}">Disapprove Samples</a>
+ <a class="btn btn-primary" href="{% url 'tbc:allot_book' proposal.proposal.id %}">Alot Book</a>
{% else %}
<h5>Contributor has not submitted sample notebook yet.</h5>
{% endif %}
diff --git a/tbc/urls.py b/tbc/urls.py
index 6d3cc17..6c75ab3 100644
--- a/tbc/urls.py
+++ b/tbc/urls.py
@@ -2,54 +2,55 @@ from django.conf.urls import patterns, include, url
urlpatterns = patterns('',
- url(r'^$', 'tbc.views.Home', name='Home'),
- url(r'^internship-forms/$', 'tbc.views.InternshipForms', name='InternshipForms'),
- url(r'^about-pythontbc/$', 'tbc.views.AboutPytbc', name='AboutPytbc'),
- url(r'^sample-notebook/$', 'tbc.views.SampleIpynb', name='SampleIpynb'),
- url(r'^register/$', 'tbc.views.UserRegister', name='UserRegister'),
- url(r'^login/$', 'tbc.views.UserLogin', name='UserLogin'),
- url(r'^logout/$', 'tbc.views.UserLogout', name='UserLogout'),
- url(r'^profile/$', 'tbc.views.UserProfile', name='UserProfile'),
- url(r'^update-profile/$', 'tbc.views.UpdateProfile', name='UpdateProfile'),
- url(r'^forgot-password/$', 'tbc.views.ForgotPassword', name='ForgotPassword'),
- url(r'^update-password/$', 'tbc.views.UpdatePassword', name='UpdatePassword'),
+ url(r'^$', 'tbc.views.home', name='home'),
+ url(r'^internship-forms/$', 'tbc.views.internship_forms', name='internship_forms'),
+ url(r'^about-pythontbc/$', 'tbc.views.about_pytbc', name='about_pytbc'),
+
+ url(r'^sample-notebook/$', 'tbc.views.sample_ipynb', name='sample_ipynb'),
+ url(r'^register/$', 'tbc.views.user_register', name='user_register'),
+ url(r'^login/$', 'tbc.views.user_login', name='user_login'),
+ url(r'^logout/$', 'tbc.views.user_logout', name='user_logout'),
+ url(r'^profile/$', 'tbc.views.user_profile', name='user_profile'),
+ url(r'^update-profile/$', 'tbc.views.update_profile', name='update_profile'),
+ url(r'^forgot-password/$', 'tbc.views.forgot_password', name='forgot_password'),
+ url(r'^update-password/$', 'tbc.views.update_password', name='update_password'),
url(r'^admin-tools/$', 'tbc.views.admin_tools', name='admin_tools'),
+
+ url(r'^submit-proposal/$', 'tbc.views.submit_proposal', name='submit_proposal'),
+ url(r'^submit-aicte-proposal/$', 'tbc.views.list_aicte', name='list_aicte'),
+ url(r'^submit-aicte-proposal/(?P<aicte_book_id>\d+)/$', 'tbc.views.submit_aicte_proposal', name='submit_aicte_proposal'),
+ url(r'^submit-book/$', 'tbc.views.submit_book', name='submit_book'),
+ url(r'^submit-sample/$', 'tbc.views.submit_sample', name='submit_sample'),
+ url(r'^submit-sample/(?P<proposal_id>\d+)$', 'tbc.views.submit_sample', name='submit_sample'),
+ url(r'^submit-sample/(?P<proposal_id>\d+)/(?P<old_notebook_id>\d+)$', 'tbc.views.submit_sample', name='submit_sample'),
+ url(r'^confirm-book-details/$', 'tbc.views.confirm_book_details', name='confirm_book_details'),
+ url(r'^submit-book-old/$', 'tbc.views.submit_book', name='submit_book'),
+ url(r'^submit-code/$', 'tbc.views.submit_code', name='submit_code'),
+ url(r'^submit-code-old/(?P<book_id>\d+)$', 'tbc.views.submit_code_old', name='submit_code_old'),
+ url(r'^update-content/(?P<book_id>\d+)$', 'tbc.views.update_content', name='update_content'),
+ url(r'^get-zip/(?P<book_id>\d+)$', 'tbc.views.get_zip', name='get_zip'),
+ url(r'^browse-books/$', 'tbc.views.browse_books', name='browse_books'),
+ url(r'^browse-books/(?P<category>.+)$', 'tbc.views.browse_books', name='browse_books'),
+ url(r'^convert-notebook/(?P<notebook_path>.+)$', 'tbc.views.convert_notebook', name='convert_notebook'),
+ url(r'^book-details/(?P<book_id>\d+)/$', 'tbc.views.book_details', name='book_details'),
+ url(r'^completed-books/$', 'tbc.views.completed_books', name='completed_books'),
+ url(r'^completed-books/(?P<category>.+)$', 'tbc.views.completed_books', name='completed_books'),
+ url(r'^books-under-progress/$', 'tbc.views.books_under_progress', name='books_under_progress'),
+ url(r'^redirect-ipynb/(?P<notebook_path>.+)$', 'tbc.views.redirect_to_ipynb', name='redirect_to_ipynb'),
+ url(r'^get-certificate/$', 'tbc.views.get_certificate', name='get_certificate'),
+ url(r'^get-certificate/(?P<book_id>\d+)/$', 'tbc.views.get_certificate', name='get_certificate'),
- url(r'^submit-proposal/$', 'tbc.views.SubmitProposal', name='SubmitProposal'),
- url(r'^submit-aicte-proposal/$', 'tbc.views.ListAICTE', name='ListAICTE'),
- url(r'^submit-aicte-proposal/(?P<aicte_book_id>\d+)/$', 'tbc.views.SubmitAICTEProposal', name='SubmitAICTEProposal'),
- url(r'^submit-book/$', 'tbc.views.SubmitBook', name='SubmitBook'),
- url(r'^submit-sample/$', 'tbc.views.SubmitSample', name='SubmitSample'),
- url(r'^submit-sample/(?P<proposal_id>\d+)$', 'tbc.views.SubmitSample', name='SubmitSample'),
- url(r'^submit-sample/(?P<proposal_id>\d+)/(?P<old_notebook_id>\d+)$', 'tbc.views.SubmitSample', name='SubmitSample'),
- url(r'^confirm-book-details/$', 'tbc.views.ConfirmBookDetails', name='ConfirmBookDetails'),
- url(r'^submit-book-old/$', 'tbc.views.SubmitBook', name='SubmitBook'),
- url(r'^submit-code/$', 'tbc.views.SubmitCode', name='SubmitCode'),
- url(r'^submit-code-old/(?P<book_id>\d+)$', 'tbc.views.SubmitCodeOld', name='SubmitCodeOld'),
- url(r'^update-content/(?P<book_id>\d+)$', 'tbc.views.UpdateContent', name='UpdateContent'),
- url(r'^get-zip/(?P<book_id>\d+)$', 'tbc.views.GetZip', name='GetZip'),
- url(r'^browse-books/$', 'tbc.views.BrowseBooks', name='BrowseBooks'),
- url(r'^browse-books/(?P<category>.+)$', 'tbc.views.BrowseBooks', name='BrowseBooks'),
- url(r'^convert-notebook/(?P<notebook_path>.+)$', 'tbc.views.ConvertNotebook', name='ConvertNotebook'),
- url(r'^book-details/(?P<book_id>\d+)/$', 'tbc.views.BookDetails', name='BookDetails'),
- url(r'^completed-books/$', 'tbc.views.CompletedBooks', name='CompletedBooks'),
- url(r'^completed-books/(?P<category>.+)$', 'tbc.views.CompletedBooks', name='CompletedBooks'),
- url(r'^books-under-progress/$', 'tbc.views.BooksUnderProgress', name='BooksUnderProgress'),
- url(r'^redirect-ipynb/(?P<notebook_path>.+)$', 'tbc.views.RedirectToIpynb', name='RedirectToIpynb'),
- url(r'^get-certificate/$', 'tbc.views.GetCertificate', name='GetCertificate'),
- url(r'^get-certificate/(?P<book_id>\d+)/$', 'tbc.views.GetCertificate', name='GetCertificate'),
-
- url(r'^book-review/$', 'tbc.views.BookReview', name='BookReview'),
- url(r'^proposal-review/$', 'tbc.views.ReviewProposals', name='ReviewProposals'),
- url(r'^proposal-review/(?P<proposal_id>\d+)/(?P<textbook_id>\d+)$', 'tbc.views.ReviewProposals', name='ReviewProposals'),
- url(r'^disapprove-sample-notebook/(?P<proposal_id>\d+)$', 'tbc.views.DisapproveProposal', name='DisapproveProposal'),
- url(r'^allot-book/(?P<proposal_id>\d+)$', 'tbc.views.AllotBook', name='AllotBook'),
- url(r'^reject-proposal/(?P<proposal_id>\d+)$', 'tbc.views.RejectProposal', name='RejectProposal'),
- url(r'^book-review/(?P<book_id>\d+)$', 'tbc.views.BookReview', name='BookReview'),
- url(r'^approve-book/(?P<book_id>\d+)$', 'tbc.views.ApproveBook', name='ApproveBook'),
- url(r'^notify-changes/(?P<book_id>\d+)$', 'tbc.views.NotifyChanges', name='NotifyChanges'),
- url(r'^brokenbooks/$', 'tbc.views.get_broken_books', name='brokenbooks'),
+ url(r'^book-review/$', 'tbc.views.book_review', name='book_review'),
+ url(r'^proposal-review/$', 'tbc.views.review_proposals', name='review_proposals'),
+ url(r'^proposal-review/(?P<proposal_id>\d+)/(?P<textbook_id>\d+)$', 'tbc.views.review_proposals', name='review_proposals'),
+ url(r'^disapprove-sample-notebook/(?P<proposal_id>\d+)$', 'tbc.views.disapprove_proposal', name='disapprove_proposal'),
+ url(r'^allot-book/(?P<proposal_id>\d+)$', 'tbc.views.allot_book', name='allot_book'),
+ url(r'^reject-proposal/(?P<proposal_id>\d+)$', 'tbc.views.reject_proposal', name='reject_proposal'),
+ url(r'^book-review/(?P<book_id>\d+)$', 'tbc.views.book_review', name='book_review'),
+ url(r'^approve-book/(?P<book_id>\d+)$', 'tbc.views.approve_book', name='approve_book'),
+ url(r'^notify-changes/(?P<book_id>\d+)$', 'tbc.views.notify_changes', name='notify_changes'),
+ url(r'^brokenbooks/$', 'tbc.views.get_broken_books', name='broken_books'),
url(r'^link-image/$', 'tbc.views.link_image', name='link_image'),
# ajax urls
diff --git a/tbc/views.py b/tbc/views.py
index 7985128..4a469c5 100755..100644
--- a/tbc/views.py
+++ b/tbc/views.py
@@ -55,7 +55,7 @@ def is_reviewer(user):
return True
-def InternshipForms(request):
+def internship_forms(request):
context = {}
images = []
if request.user.is_anonymous():
@@ -68,11 +68,11 @@ def InternshipForms(request):
return render_to_response('tbc/internship-forms.html', context)
-def SampleIpynb(request):
+def sample_ipynb(request):
return render_to_response('tbc/sample.html')
-def AboutPytbc(request):
+def about_pytbc(request):
context = {}
images = []
if request.user.is_anonymous():
@@ -85,7 +85,7 @@ def AboutPytbc(request):
return render_to_response('tbc/about-pytbc.html', context)
-def Home(request):
+def home(request):
context = {}
images = []
if request.user.is_anonymous():
@@ -122,7 +122,7 @@ def Home(request):
if 'bookupdate' in request.GET:
context['bookupdate'] =True
- books = Book.objects.filter(approved=True).order_by("-id")[0:6]
+ books = Book.objects.filter(approved=True).order_by("-id")
for book in books:
try:
images.append(ScreenShots.objects.filter(book=book)[0])
@@ -152,11 +152,11 @@ def Home(request):
return render_to_response('base.html', context)
-def _checkProfile(user):
+def _checkprofile(user):
return Profile.objects.filter(user=user).exists()
-def UserLogin(request):
+def user_login(request):
context = {}
context.update(csrf(request))
if 'require_login' in request.GET:
@@ -197,7 +197,7 @@ def UserLogin(request):
return render_to_response('tbc/login.html', context)
-def UserRegister(request):
+def user_register(request):
context = {}
context.update(csrf(request))
if request.method == 'POST':
@@ -224,7 +224,7 @@ def UserRegister(request):
return render_to_response('tbc/register.html', context)
-def UserProfile(request):
+def user_profile(request):
context = {}
user = request.user
if user.is_authenticated():
@@ -256,13 +256,13 @@ def UserProfile(request):
return HttpResponseRedirect('/login/?require_login=True')
-def UpdateProfile(request):
+def update_profile(request):
user = request.user
context = {}
context.update(csrf(request))
if user.is_anonymous():
return HttpResponseRedirect('/login/?require_login=True')
- if not _checkProfile(user):
+ if not _checkprofile(user):
return HttpResponseRedirect("/profile/?update=profile")
context['user'] = user
user_profile = Profile.objects.get(user=user)
@@ -290,7 +290,7 @@ def UpdateProfile(request):
context['form'] = form
return render_to_response('tbc/update-profile.html', context)
-def UserLogout(request):
+def user_logout(request):
user = request.user
if user.is_authenticated() and user.is_active:
logout(request)
@@ -298,7 +298,7 @@ def UserLogout(request):
return redirect('/?logout=done')
-def ForgotPassword(request):
+def forgot_password(request):
context = {}
user_emails = []
context.update(csrf(request))
@@ -328,7 +328,7 @@ def ForgotPassword(request):
return render_to_response("tbc/forgot-password.html", context)
-def UpdatePassword(request):
+def update_password(request):
context = {}
user = request.user
context.update(csrf(request))
@@ -366,14 +366,14 @@ def UpdatePassword(request):
return render_to_response("tbc/login.html", context)
-def SubmitBook(request):
+def submit_book(request):
context = {}
if request.user.is_anonymous():
return HttpResponseRedirect("/login/?require_login=true")
else:
curr_user = request.user
if curr_user.is_authenticated():
- if not _checkProfile(curr_user):
+ if not _checkprofile(curr_user):
return HttpResponseRedirect("/profile/?update=profile")
user_profile = Profile.objects.get(user=curr_user)
curr_proposals = Proposal.objects.filter(user=user_profile)
@@ -414,9 +414,9 @@ def SubmitBook(request):
-def SubmitCodeOld(request, book_id=None):
+def submit_code_old(request, book_id=None):
user = request.user
- if not _checkProfile(user):
+ if not _checkprofile(user):
return HttpResponseRedirect("/profile/?update=profile")
curr_profile = Profile.objects.get(user=user)
context = {}
@@ -456,9 +456,9 @@ def SubmitCodeOld(request, book_id=None):
return render_to_response('tbc/upload-content-old.html', context)
-def SubmitProposal(request):
+def submit_proposal(request):
curr_user = request.user
- if not _checkProfile(curr_user):
+ if not _checkprofile(curr_user):
return HttpResponseRedirect("/profile/?update=profile")
user_profile = Profile.objects.get(user=curr_user.id)
context = {}
@@ -537,12 +537,12 @@ Thank you for showing interest in contributing to Python Textbook Companion Acti
return HttpResponseRedirect('/?proposal_pending=True')
-def ListAICTE(request):
+def list_aicte(request):
if request.user.is_anonymous():
return HttpResponseRedirect('/login/?require_login=True')
else:
curr_user = request.user
- if not _checkProfile(curr_user):
+ if not _checkprofile(curr_user):
return HttpResponseRedirect("/profile/?update=profile")
user_profile = Profile.objects.get(user=curr_user.id)
user_proposals = Proposal.objects.filter(user=user_profile)
@@ -565,12 +565,12 @@ def ListAICTE(request):
return render_to_response('tbc/aicte-books.html', context)
-def SubmitAICTEProposal(request, aicte_book_id=None):
+def submit_aicte_proposal(request, aicte_book_id=None):
if request.user.is_anonymous():
return HttpResponseRedirect('/login/?require_login=True')
else:
curr_user = request.user
- if not _checkProfile(curr_user):
+ if not _checkprofile(curr_user):
return HttpResponseRedirect("/profile/?update=profile")
user_profile = Profile.objects.get(user=curr_user.id)
context = {}
@@ -637,7 +637,7 @@ def SubmitAICTEProposal(request, aicte_book_id=None):
return HttpResponseRedirect('/?proposal_pending=True')
-def ReviewProposals(request, proposal_id=None, textbook_id=None):
+def review_proposals(request, proposal_id=None, textbook_id=None):
context = {}
user = request.user
if is_reviewer(user):
@@ -689,7 +689,7 @@ def ReviewProposals(request, proposal_id=None, textbook_id=None):
return HttpResponse("not allowed")
-def DisapproveProposal(request, proposal_id=None):
+def disapprove_proposal(request, proposal_id=None):
context = {}
context.update(csrf(request))
proposal = Proposal.objects.get(id=proposal_id)
@@ -709,7 +709,7 @@ def DisapproveProposal(request, proposal_id=None):
return render_to_response('tbc/disapprove-sample.html', context)
-def AllotBook(request, proposal_id=None):
+def allot_book(request, proposal_id=None):
context = {}
proposal = Proposal.objects.get(id=proposal_id)
proposal.status = "book alloted"
@@ -721,7 +721,7 @@ def AllotBook(request, proposal_id=None):
return HttpResponseRedirect("/book-review/?book_alloted=done")
-def RejectProposal(request, proposal_id=None):
+def reject_proposal(request, proposal_id=None):
context = {}
context.update(csrf(request))
proposal = Proposal.objects.get(id=proposal_id)
@@ -746,13 +746,13 @@ def RejectProposal(request, proposal_id=None):
return render_to_response('tbc/reject-proposal.html', context)
-def SubmitSample(request, proposal_id=None, old_notebook_id=None):
+def submit_sample(request, proposal_id=None, old_notebook_id=None):
context = {}
if request.user.is_anonymous():
return HttpResponseRedirect('/login/?require_login=True')
else:
user = request.user
- if not _checkProfile(user):
+ if not _checkprofile(user):
return HttpResponseRedirect("/profile/?update=profile")
context.update(csrf(request))
if request.method == "POST":
@@ -793,13 +793,13 @@ def SubmitSample(request, proposal_id=None, old_notebook_id=None):
return render_to_response('tbc/submit-sample.html', context)
-def ConfirmBookDetails(request):
+def confirm_book_details(request):
context = {}
if request.user.is_anonymous():
return HttpResponseRedirect('/login/?require_login=True')
else:
current_user = request.user
- if not _checkProfile(current_user):
+ if not _checkprofile(current_user):
return HttpResponseRedirect("/profile/?update=profile")
user_profile = Profile.objects.get(user=current_user)
try:
@@ -843,12 +843,14 @@ def ConfirmBookDetails(request):
return render_to_response('tbc/confirm-details.html', context)
-def SubmitCode(request):
+
+
+def submit_code(request):
if request.user.is_anonymous():
return HttpResponseRedirect('/login/?require_login=True')
else:
user = request.user
- if not _checkProfile(user):
+ if not _checkprofile(user):
return HttpResponseRedirect("/profile/?update=profile")
curr_profile = Profile.objects.get(user=user)
context = {}
@@ -943,7 +945,7 @@ def SubmitCode(request):
return render_to_response('tbc/upload-content.html', context)
-def UpdateContent(request, book_id=None):
+def update_content(request, book_id=None):
context = {}
if request.user.is_anonymous():
return HttpResponseRedirect('/login/?require_login=True')
@@ -983,7 +985,7 @@ def UpdateContent(request, book_id=None):
return render_to_response('tbc/update-content.html', context)
-def generateZip(book_id):
+def generate_zip(book_id):
book = Book.objects.get(id=book_id)
files_to_zip = []
file_path = os.path.abspath(os.path.dirname(__file__))
@@ -1003,7 +1005,7 @@ def generateZip(book_id):
return s, zipfile_name
-def GetZip(request, book_id=None):
+def get_zip(request, book_id=None):
user = request.user
s, zipfile_name = generateZip(book_id)
resp = HttpResponse(s.getvalue(), mimetype = "application/x-zip-compressed")
@@ -1011,7 +1013,7 @@ def GetZip(request, book_id=None):
return resp
-def BookDetails(request, book_id=None):
+def book_details(request, book_id=None):
context = {}
if request.user.is_anonymous():
context['anonymous'] = True
@@ -1029,7 +1031,7 @@ def BookDetails(request, book_id=None):
return render_to_response('tbc/book-details.html', context)
-def BookReview(request, book_id=None):
+def book_review(request, book_id=None):
context = {}
if is_reviewer(request.user):
if book_id:
@@ -1066,7 +1068,7 @@ def BookReview(request, book_id=None):
return render_to_response('tbc/forbidden.html')
-def ApproveBook(request, book_id=None):
+def approve_book(request, book_id=None):
context = {}
user = request.user
if is_reviewer(request.user):
@@ -1120,7 +1122,7 @@ Congratulations !\nThe book - """+book.title+""" is now complete & published.\nP
return render_to_response('tbc/forbidden.html')
-def NotifyChanges(request, book_id=None):
+def notify_changes(request, book_id=None):
context = {}
if is_reviewer(request.user):
book = Book.objects.get(id=book_id)
@@ -1156,7 +1158,7 @@ def NotifyChanges(request, book_id=None):
return render_to_response('tbc/forbidden.html')
-def BrowseBooks(request):
+def browse_books(request):
context = {}
category = None
images = []
@@ -1189,10 +1191,10 @@ def BrowseBooks(request):
return render_to_response('tbc/browse-books.html', context)
-def ConvertNotebook(request, notebook_path=None):
+
+def convert_notebook(request, notebook_path=None):
""" Checks for the modified time of ipython notebooks and corresponding html page and replaces html page with
new one if corresponding ipython notebook has been modified. """
-
context = {}
path = os.path.join(local.path, notebook_path.rsplit(".", 1)[0])
template_html = path+".html"
@@ -1216,7 +1218,7 @@ def ConvertNotebook(request, notebook_path=None):
return render_to_response(template_html, context)
-def CompletedBooks(request):
+def completed_books(request):
context = {}
context.update(csrf(request))
category = "All"
@@ -1240,7 +1242,7 @@ def CompletedBooks(request):
return render_to_response('tbc/completed_books.html', context)
-def BooksUnderProgress(request):
+def books_under_progress(request):
context = {}
context.update(csrf(request))
if request.user.is_anonymous():
@@ -1263,7 +1265,7 @@ def BooksUnderProgress(request):
return render_to_response('tbc/books_under_progress.html', context)
-def GetCertificate(request, book_id=None):
+def get_certificate(request, book_id=None):
if request.user.is_anonymous():
return HttpResponseRedirect('/login/?require_login=True')
else:
@@ -1340,7 +1342,7 @@ def _make_tbc_certificate(path):
err = process.communicate()[1]
return process.returncode, err
-def RedirectToIpynb(request, notebook_path=None):
+def redirect_to_ipynb(request, notebook_path=None):
context = {}
notebook = notebook_path.split("/")
notebook[0] = "notebooks"