From 392891077a43bd57216327d0c8a764e5dcf3cb71 Mon Sep 17 00:00:00 2001 From: Jeff Lindsay Date: Fri, 26 Mar 2010 19:06:00 -0700 Subject: [PATCH] hello world with templates and other dojo stuff --- NOTES | 35 +++++++++++++++++++++++++++++++++++ app.yaml | 10 +++++++++- main.py | 13 ++++++++++--- static/dojo_icon.png | Bin 0 -> 4308 bytes static/favicon.ico | Bin 0 -> 183 bytes static/robots.txt | 2 ++ static/style.css | 33 +++++++++++++++++++++++++++++++++ templates/base.html | 26 ++++++++++++++++++++++++++ templates/main.html | 6 ++++++ 9 files changed, 121 insertions(+), 4 deletions(-) create mode 100644 NOTES create mode 100644 static/dojo_icon.png create mode 100644 static/favicon.ico create mode 100644 static/robots.txt create mode 100644 static/style.css create mode 100644 templates/base.html create mode 100644 templates/main.html diff --git a/NOTES b/NOTES new file mode 100644 index 0000000..b783e1d --- /dev/null +++ b/NOTES @@ -0,0 +1,35 @@ +requirements +============ +-members only access +-members can post updates +-members can comment on updates +-members can get emailed updates + +wishlist +======== +-gravatars for icons +-tags in general (pretty useful) +-linked mentions for other members +-members get notifications with notify.io +-post daily archive to staff wiki +-"share publicly" that lets bubble up to twitter +-multiple log streams (tags? tabs?) +-integrate Buzz/"activitystrea.ms" standards + +model +===== +Update + -created + -updated + -body + -user + +Comment + -created + -updated + -body + -user + -update (reference) + +Profile + -wants_emails \ No newline at end of file diff --git a/app.yaml b/app.yaml index 4776eda..f9f19a9 100644 --- a/app.yaml +++ b/app.yaml @@ -4,5 +4,13 @@ runtime: python api_version: 1 handlers: +- url: /favicon.ico + static_files: static/favicon.ico + upload: static/favicon.ico +- url: /robots.txt + static_files: static/robots.txt + upload: static/robots.txt +- url: /static + static_dir: static - url: .* - script: main.py + script: main.py \ No newline at end of file diff --git a/main.py b/main.py index 9766335..0243d40 100755 --- a/main.py +++ b/main.py @@ -1,10 +1,17 @@ -from google.appengine.ext import webapp -from google.appengine.ext.webapp import util +from google.appengine.ext import webapp, db +from google.appengine.ext.webapp import util, template + +class Update(db.Model): + user = db.UserProperty(auto_current_user_add=True) + body = db.StringProperty(required=True) + created = db.DateTimeProperty(auto_now_add=True) + class MainHandler(webapp.RequestHandler): def get(self): - self.response.out.write('Hello world!') + your_name = "Jeff" + self.response.out.write(template.render('templates/main.html', locals())) def main(): diff --git a/static/dojo_icon.png b/static/dojo_icon.png new file mode 100644 index 0000000000000000000000000000000000000000..3590a9210cff8b54c91129cd224b193cf0790092 GIT binary patch literal 4308 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 gEo+V7OCvd`}x}2%5DyF8HO_0GF0M0l?%K!iX literal 0 HcmV?d00001 diff --git a/static/robots.txt b/static/robots.txt new file mode 100644 index 0000000..14267e9 --- /dev/null +++ b/static/robots.txt @@ -0,0 +1,2 @@ +User-agent: * +Allow: / \ No newline at end of file diff --git a/static/style.css b/static/style.css new file mode 100644 index 0000000..34cc42f --- /dev/null +++ b/static/style.css @@ -0,0 +1,33 @@ +body { font-family: Verdana,Arial,sans-serif; margin: 0px;} +#wrapper { margin-left: auto; margin-right: auto; width: 700px; } + +#top a:visited { color: blue;} +#top { height: 20px; border-bottom: 1px solid #ccc; text-align: right; font-size: 12px; padding-right: 5px; padding-top: 4px; } + +#header { margin-left: auto; margin-right: auto; width: 670px; height: 125px;} +#header img { margin-right: 10px;} +#header h1 { font-size: 42px; margin-top: 20px; padding-top: 10px; margin-bottom: 0px; padding-bottom: 0px;} +#header h2 { font-size: x-large; margin: 0px; } + +.step span { color: white; background-color: #b10026; padding: 1px; padding-left: 4px; padding-right: 4px;} +.step.inactive span { background-color: gray;} +.step.inactive { color: gray; } + +h3 { margin-top: 0px;} +h4 { margin-bottom: 0px;} + +table td { padding-left: 10px; padding-top: 4px;} + +form div { margin-top: 10px; } + +label { display: block; font-size: smaller;} + +a:visited { color: blue;} + +#content { border-top: 3px solid #d50025; background: #eee; padding: 10px; } +#primary { background: white; width: 660px; padding: 10px; -moz-border-radius: 8px; -webkit-border-radius: 8px;} +h4 { font-size: smaller; } + +.label { font-size: smaller; font-weight: bold; margin-top: 10px;} +#content h2 { margin-bottom: 5px; margin-top: 5px;} +#content table { margin-bottom: 20px;} \ No newline at end of file diff --git a/templates/base.html b/templates/base.html new file mode 100644 index 0000000..cb66c14 --- /dev/null +++ b/templates/base.html @@ -0,0 +1,26 @@ + + + Hacker Dojo Log + + + +
+ {% if user %} + {{user.email}} | Logout + {% else %} + Login | Need an account? + {% endif %} +
+
+ +
+ {% block content %}{% endblock %} +
+
+ + + \ No newline at end of file diff --git a/templates/main.html b/templates/main.html new file mode 100644 index 0000000..99899c5 --- /dev/null +++ b/templates/main.html @@ -0,0 +1,6 @@ +{% extends 'base.html' %} +{% block content %} + +Hello world, {{your_name}}! + +{% endblock %} \ No newline at end of file