]> git.plutz.net Git - shellwiki/blobdiff - themes/default.sh
Merge commit '8ed7045912937148dd46554178e675df8493f46c'
[shellwiki] / themes / default.sh
index c096f8218a03639d6b24352c4ed4228df515993d..c99477bc4d99c54cb6b3362d04bedc1ff0dcd862 100755 (executable)
@@ -1,10 +1,16 @@
 #!/bin/sh
 
+. "$_EXEC/tools.sh"
+
 theme_head(){
+  local IFS="$BR"
   printf '
   <meta name="viewport" content="width=device-width"/>
-  <link rel="stylesheet" type="text/css" href="%s/[.]/cgilite/common.css">
-  ' "$_BASE"
+  '
+  for css in "$_BASE/[.]/cgilite/common.css" "$_BASE/[.]/themes/default.css" $PAGE_CSS; do
+    printf  '<link rel="stylesheet" type="text/css" href="%s">' \
+            "$(HTML "${css##*//}")"
+  done
 }
 
 theme_header(){
@@ -12,64 +18,140 @@ theme_header(){
 }
 
 theme_footer(){
-  printf '<footer>%s</footer>' "$(wiki '[wiki]/footer/' ||echo No footer)"
+  printf '<footer>%s</footer>' "$(wiki '[wiki]/footer/')"
+}
+
+theme_pagemenu(){
+  local page="$1"
+
+  if acl_write "$page"; then
+    printf  '
+    <ul class="pagemenu">
+      <li><a href="./[view]">View</a></li>
+      <li><a href="./[edit]">Edit</a></li>
+      <li><a href="./[attachment]">Attachments</a></li>
+      <li><a href="./[revision]">Revisions</a></li>
+      <li><a href="./[rename]">Rename</a></li>
+      <li><a href="./[move]">Move</a></li>
+      <li><a href="./[delete]">Delete</a></li>
+    </ul>'
+  fi
 }
 
 theme_page(){
-  local page="$1" title
-  title="${page%/}"; title="${title##*/}"
+  local page="$1" title="$2"
+  title="$(HTML "${title:-"${page}"}")"
 
-  # Important! Web Server response including newline newline
+  # Important! Web Server response including newline
   printf "%s\r\n" "Content-Type: text/html; charset=utf-8" ""
 
   cat <<-EOF
        <!DOCTYPE HTML>
        <html><head>
          $(theme_head)
-         <title>$(HTML "${title}")</title>
-       </head><body id="$(HTML "$page")">
+         <title>${title}</title>
+       </head><body id="$(HTML "${PATH_INFO}")">
          $(theme_header)
-         <main>$(wiki "$page" || printf 'Page not found')</main>
+         <main>
+           $(theme_pagemenu)
+           $(if [ "$page" = '-' ]; then
+               cat
+             else
+               printf '<article>'
+               wiki "$page"
+               printf '</article>'
+           fi)
+         </main>
          $(theme_footer)
        </body></html>
        EOF
 }
 
 theme_editor(){
-  local page="$1" title
+  local page="$1" template="$2" title
   title="${page%/}"; title="${title##*/}"
 
-  # Important! Web Server response including newline
-  printf "%s\r\n" "Content-Type: text/html; charset=utf-8" ""
+  [ "$template" ] && acl_read "$template" || template="$page"
 
-  cat <<-EOF
-       <!DOCTYPE HTML>
-       <html><head>
-         $(theme_head)
-         <title>$(HTML "${title}")</title>
-       </head><body id="$(HTML "$page")" class="editor">
-         $(theme_header)
-         <main><form method=POST>
-           <input type=hidden name=session_key value="${SESSION_KEY}"/>
-            <textarea name=pagetext>$(wiki_text "$page" |HTML)</textarea>
-            <button type=submit name=action value=update>Update</button>
-            <button type=submit name=action value=cancel>Cancel</button>
-          </form></main>
-         $(theme_footer)
-       </body></html>
+  theme_page - "Editor: $title" <<-EOF
+       <form method=POST action="$(HTML "${_BASE}${page%/}/[edit]")">
+         <input type=hidden name=session_key value="${SESSION_KEY}"/>
+         <textarea name=pagetext>$({ wiki_text "$page" \
+                                  || wiki_text "$template"; } |HTML)</textarea>
+         <button type=submit name=action value=update>Update</button>
+         <button type=submit name=action value=cancel>Cancel</button>
+       </form>
        EOF
 }
 
-theme_login(){
-  theme_page '[wiki]/login/'
+theme_revisions(){
+  local page="$1" title
+  title="${page%/}"; title="${title##*/}"
+
+ "$_EXEC/macros/revisions" "$page" \
+  | theme_page - "Revisions: $title"
 }
 
-theme_register(){
-  theme_page '[wiki]/register/'
+theme_attachments(){
+  local page="$1" title
+  title="${page%/}"; title="${title##*/}"
+
+  if acl_write "$page"; then
+    theme_page - "Attachments: $title" <<-EOF
+       <form class=upload method=POST enctype="multipart/form-data">
+         <input type=hidden name=session_id value="$SESSION_ID">
+         <input type=file name=file multiple>
+         <button type=submit name=action value=upload>Upload</button>
+       </form>
+       
+       <form method=POST><ul class="attachment list">
+         <input type=hidden name=session_key value="$SESSION_KEY">
+       $(for file in "$_EXEC/pages/$page/#attachments"/* "$_DATA/pages/$page/#attachments"/*; do
+         [ "$file" = "$_EXEC/pages/$page/#attachments/${file##*/}" \
+               -a -f "$_DATA/pages/$page/#attachments/${file##*/}" ] && continue
+         stat="$(stat -c '%s %Y' -- "$file" 2>&-)" || continue
+         size="${stat% *}" date="${stat#* }"
+          hfile="$(HTML "${file##*/}")"
+       
+         printf '<li><button type=submit name=delete value="%s">Delete</button><a class=name href="[attachment]/%s">%s</a>
+                 <span class=size>%s</span><span class=date>%s</span></li>' \
+                "$hfile" "$hfile" "$hfile" "$(size_human "$size")" "$(date -d @"$date" +"%F %T")"
+       done)
+       </ul></form>
+       EOF
+  else
+    theme_page - "Attachments: $title" <<-EOF
+       <ul class="attachment list">
+       $(for file in "$_EXEC/pages/$page/#attachments"/* "$_DATA/pages/$page/#attachments"/*; do
+         [ "$file" = "$_EXEC/pages/$page/#attachments/${file##*/}" \
+               -a -f "$_DATA/pages/$page/#attachments/${file##*/}" ] && continue
+         stat="$(stat -c '%s %Y' -- "$file" 2>&-)" || continue
+         size="${stat% *}" date="${stat#* }"
+          hfile="$(HTML "${file##*/}")"
+       
+         printf '<li><a class=name href="%s">%s</a>
+                 <span class=size>%s</span><span class=date>%s</span></li>' \
+                "$hfile" "$hfile" "$(size_human "$size")" "$(date -d @"$date" +"%F %T")"
+       done)
+       </ul>
+       EOF
+  fi
 }
 
-theme_404(){
-  printf "%s\r\n" "Status: 404 Not Found"
+theme_error(){
+  local errno="$1"
+
+  case $errno in
+    400) printf "%s\r\n" "Status: 400 Bad Request";;
+    403) printf "%s\r\n" "Status: 403 Forbidden";;
+    404) printf "%s\r\n" "Status: 404 Not Found";;
+    409) printf "%s\r\n" "Status: 409 Conflict";;
+    500) printf "%s\r\n" "Status: 500 Internal Server Error";;
+  esac
 
-  theme_page '[wiki]/404/'
+  if [ "$(mdfile "/[wiki]/$errno/")" ]; then
+    theme_page "/[wiki]/$errno/"
+  else
+    printf "Content-Length: 0\r\n\r\n"
+  fi
 }