X-Git-Url: http://git.plutz.net/?a=blobdiff_plain;f=list.sh;h=fa657d10415d6a3deb4968799b93c874346190a5;hb=84232e55d22c7ae59ff9709e350d739813c6aaf6;hp=324d8eb29007e6e548b63da225b25595ac723a90;hpb=a3df4e8f297a16faf93847dab6cbd15d6e524e73;p=serve0 diff --git a/list.sh b/list.sh index 324d8eb..fa657d1 100644 --- a/list.sh +++ b/list.sh @@ -1,34 +1,33 @@ #!/bin/sh +. "$_EXEC/indexmeta.sh" + list_item() { name="$(HTML "$1")" path="$(HTML "$ITEM/$1")" - meta="$_DATA/$ITEM/$1"; meta="${meta%/*}/.index/meta" if [ -d "$_DATA/$ITEM/$1" ]; then printf '[a .list .dir href="%s?%s" %s]' \ "$path" "$(HTML "$QUERY_STRING")" "$name" - elif [ -f "$meta" ]; then + else read -r length width height tags comment n <<-EOF - $(grep -m1 -F " ${1##*/}" "$meta") + $(meta_info "$_DATA/$ITEM/$1") EOF printf '[div .list .file [a href="%s" [img src="%s?a=thumbnail"][label %s]] [span .time %i:%imin] [span .dim %ix%i] %s + [checkbox "select" "%s" id="select_%s" form="multitag"][label for="select_%s" +] ]' \ "$path" "$path" "$name" \ "$((length / 60))" "$((length % 60))" \ "$width" "$height" \ - "$(printf %s\\n "${tags#tags=}" |tr , ' ' |xargs printf '[span .tag %s]')" - else - printf '[div .list .file [a href="%s" [img src="%s?a=thumbnail"][label %s]]]' \ - "$path" "$path" "$name" + "$(UNSTRING "${tags#tags=}" |tr , '\0' |xargs -r0 printf ' [span .tag %s]')" \ + "$path" "$path" "$path" fi } list_fs_browse(){ - [ -d "$_DATA/$ITEM/.index" -a \! "$_DATA/$ITEM" -ot "$_DATA/$ITEM/.index/meta" ] \ - && dir="$_DATA/$ITEM" . "$_EXEC/update_meta.sh" + meta_dir "$_DATA/$ITEM" (cd "$_DATA/$ITEM"; find ./ -type d \! -name .index -mindepth 1 -maxdepth 1 \ -exec stat -c '%Y %n' '{}' + @@ -39,8 +38,7 @@ list_fs_browse(){ list_fs_index(){ find "$_DATA/$ITEM" -type d -name .index \ | while d="$(line)"; do - [ ! "${d%/.index}" -ot "$d/meta" ] \ - && dir="${d%/.index}" . "$_EXEC/update_meta.sh" + meta_dir "${d%/.index}" done (cd "$_DATA/$ITEM"; find ./ \! -path '*/.index/*' -type f \ @@ -50,8 +48,7 @@ list_fs_index(){ list_browse(){ meta="$_DATA/$ITEM/.index/meta" - [ -d "${meta%/meta}" -a \! "$_DATA/$ITEM" -ot "${meta}" ] \ - && dir="$_DATA/$ITEM" . "$_EXEC/update_meta.sh" + meta_dir "$_DATA/$ITEM" (cd "$_DATA/$ITEM"; find ./ -type d \! -name .index -mindepth 1 -maxdepth 1 \ ) | cut -d/ -f2- | sort @@ -65,12 +62,13 @@ list_index(){ find ./ -path '*/.index/meta' ) | while meta="$(line)"; do base="${meta%/.index/meta}" - [ \! "$_DATA/$ITEM/$base" -ot "$_DATA/$ITEM/$meta" ] \ - && dir="$_DATA/$ITEM/$base" . "$_EXEC/update_meta.sh" + meta_dir "$_DATA/$ITEM/$base" cut -f1,6- <"$_DATA/$ITEM/$meta" \ | while f="$(line)"; do - [ -e "$_DATA/$ITEM/$base/${f#* }" ] \ - && printf '%s %s\n' "${f%% *}" "${base}/${f#* }" + fn="$(printf '%s\n' "$_DATA/$ITEM/$base/${f#* }".*)" + fn="${fn%%${BR}*}"; fn="${fn##*/}" + [ -e "$_DATA/$ITEM/$base/${fn}" ] \ + && printf '%s %s\n' "${f%% *}" "${base}/${fn}" done done \ | sort -n \ @@ -119,6 +117,33 @@ list_paginate() { printf ']' } +w_tagging(){ + printf '[div #multitag [input type="hidden" name="ref" value="%s"]' "$(HTML "$REQUEST_URI")" + printf '[a href="#" Hide][br]' + tags="$(find "$_DATA/$ITEM" -path '*/.index/meta' -exec cut -f4 '{}' + \ + | cut -d= -f2- |tr , '\n' | sort -u)" + tags="$(UNSTRING "$tags")" + + printf '[fieldset [legend %s:][select name=tag size=4 multiple' "Tags" + printf %s "$tags" |grep -vF ":" |grep -vxF '' \ + | while read -r tag; do + printf '[option value="%s" %s]' "$(HTML "$tag")" "$(HTML "$tag")" + done + printf ']]' + + printf %s "$tags" |cut -sd: -f1 |sort -u \ + | while read -r category; do + printf '[fieldset [legend %s:][select name=tag size=4 multiple' "$(HTML "$category")" + printf %s "$tags" |grep -wF "${category}" \ + | while read -r tag; do + printf '[option value="%s" %s]' "$(HTML "$tag")" "$(HTML "${tag#*:}")" + done + printf ']]' + done + + printf '[fieldset [legend New:][textarea name=newtag\n][button type=Submit Add Tags]]]' +} + printf 'Content-Type: text/html;charset=utf-8\r\n\r\n' "$_EXEC/cgilite/html-sh.sed" <<-EOF @@ -134,11 +159,14 @@ printf 'Content-Type: text/html;charset=utf-8\r\n\r\n' ] $(w_prefs) - $(list_items \ - | list_paginate - ) - [div #editing - $(w_index) + [form method=POST action="?a=multitag" + $(list_items \ + | list_paginate + ) + [div #editing + [a href="#multitag" Add Tags] $(w_tagging) + $(w_index) + ] ] ] ] EOF