X-Git-Url: https://git.plutz.net/?p=confetti;a=blobdiff_plain;f=pages%2Fattendees.sh;h=f40f82dc6da1c8c818e6367d63ff74d21f8e900a;hp=9ea073e6a1c2b5e965c13af98207c4e423538970;hb=28c5fc2fa939cc3a2ac0b82287ec38c24c1a0063;hpb=9da739230659371a860e93dcaf3765b977e30de7 diff --git a/pages/attendees.sh b/pages/attendees.sh index 9ea073e..f40f82d 100755 --- a/pages/attendees.sh +++ b/pages/attendees.sh @@ -1,8 +1,16 @@ #!/bin/sh -[ "$_GET[\"action\"]" = "del_filter" ] && _GET["filter"]="" && _GET["filtertype"]="" +[ -z "$_GET[\"order\"]" ] && _GET["order"]=firstname + +listcourses() { + ls -1 ${_DATA}/ical/*ics |while read file; do + icstime="$(sed -rn 's:^DTSTART\:(TZID=.*\:)?([0-9]{4})([0-9]{2})([0-9]{2})T([0-9]{2})([0-9]{2})([0-9]{2})Z?\r$:\2-\3-\4 \5\:\6\:\7:p' "$file")" + echo "$(date -d "$icstime" "+%u %H%M%S")\t$file" + done |sort |sed -r 's:^.*\t(.*/)([^/]+)$:\2:' +} + listcards() { - case "$_GET["filtertype"]" in + case "$_GET[\"filtertype\"]" in any) grep -il "$_GET[\"filter\"]" ${_DATA}/vcard/*vcf ;; @@ -23,9 +31,31 @@ listcards() { ;; course) ;; - *) ls -1 ${_DATA}/vcard/*vcf + *) ls -1 ${_DATA}/vcard/*vcf 2>/dev/null + ;; + esac |case "$_GET[\"order\"]" in + firstname) + while read file; do + fn=$(sed -rn 's:^N(;.+)*\:([^;]*;){1} *([^;]*).*$:\3:p' "$file") + echo "$fn\t$file" + done + ;; + lastname) + while read file; do + ln=$(sed -rn 's:^N(;.+)*\:([^;]*;){0} *([^;]*).*$:\3:p' "$file") + echo "$ln\t$file" + done ;; - esac + bdate) + while read file; do + bd=$(sed -rn 's:^BDAY(;.+)*\:(.*)$:\2:p' "$file") + echo "$bd\t$file" + done + ;; + *) + sed -r 's:^.*$:x\t&:' + ;; + esac |sort |sed -r 's:^.*\t(.*/)([^/]+)$:\2:' } vcf_parse() { @@ -35,7 +65,7 @@ vcf_parse() { s:^X-MS-CARDPICTURE:001 PHOTO:p; s:^LOGO:002 LOGO:p; s:^FN:003 FN:p; - s:^N:004 N:p + s:^N[\:;]:004 &:p s:^NICKNAME:005 NICKNAME:p; s:^SOUND:006 SOUND:p; s:^GENDER:007 GENDER:p; @@ -67,6 +97,7 @@ vcf_parse() { s:^X-EVOLUTION-BLOG-URL:021 URL:p; s:^LANG:022 LANG:p; s:^NOTE:023 NOTE:p; + s:^UID:026 UID:p; s:^RELATED:025 RELATED:p; s:^AGENT:025 RELATED\;TYPE=agent:p; @@ -96,13 +127,12 @@ vcf_parse() { s:^SORT-STRING.*$::; s:^SOURCE.*$::; s:^TZ.*$::; - s:^UID.*$::; s:^VERSION.*$:000 VERSION\:4.0:p; s:^XML.*$::; s:^([A-Z].*)$:024 \1:p; ' \ - | sort |while read -r line; do + |sort |while read -r line; do case "$line" in 00[012]*) echo -E "$line" @@ -116,16 +146,19 @@ vcf_parse() { |sed -r 's:,: :;s:\;: :g;s: +: :g' \ |tr -d '\r' ) + echo -E "$line" ;; 005*) nick=$(echo -E "$line" |sed -r 's:^[0-9]{3} ([^;\:]+)(;[^"\:]+|;"[^"]+")*\:(.*)$:\3:g' |tr -d '\r') + echo -E "$line" ;; - *) [ -n "$n" ] && fn="$n" - [ -n "$fn" -a -n "$nick" ] && fn="$fn aka. $nick" - [ -n "$fn" ] && echo -E "003 FN:$fn" \ + *) + [ -n "$n" ] && fn="$n" + #[ -n "$fn" -a -n "$nick" ] && fn="$fn aka. $nick" + [ -n "$fn" ] && echo -E "003 FN:$fn" \ || echo -E "003 FN:$nick" - echo -E "$line" - cat + echo -E "$line" + cat ;; esac done |tr -d '\r' \ @@ -150,7 +183,84 @@ vcf_parse() { done ;; esac + done \ + | sed -r 's:[\\$`]:\\&:g' +} + +view_attendee() { #Parameter: Cardfile + id="$1" + cardfile="$_DATA/vcard/${id}" + cachefile="$_DATA/cache/${id}.cache" + unset key + if [ "$cachefile" -nt "$cardfile" ]; then + cat "$cachefile" + else + declare -A tags + declare -A values + vcf_parse "$cardfile" |while read -r line; do + declare -A tag + case "$line" in + value*) eval "$line";; + tag*) eval "$line";; + key*) + if [ -z "$key" ]; then + eval "$line" + else + values[$key]="$value" + for t in ${(k)tag}; do + tags[${key}_$t]="$tag[$t]" + done + eval "$line" + if [ -n "$values[$key]" ]; then + n=0 + while [ -n "$values[$key$n]" ]; do n=$(($n + 1)); done + key=$key$n + fi + unset value + unset tag + fi + ;; + esac + done + . ${_EXEC}/templates/view_attendee.sh |tee "$cachefile" + fi +} + +edit_attendee() { #Parameter: Cardfile + id="$1" + cardfile="$_DATA/vcard/$id" + tempfile="$_DATA/temp/$id" + [ -f "$tempfile" ] && cardfile="$tempfile" + unset key + + declare -A tags + declare -A values + vcf_parse "$cardfile" |while read -r line; do + declare -A tag + case "$line" in + value*) eval "$line";; + tag*) eval "$line";; + key*) + if [ -z "$key" ]; then + eval "$line" + else + [ -n "$value" ] && values[$key]="$value" || values[$key]='\r' + for t in ${(k)tag}; do + tags[${key}_$t]="$tag[$t]" + done + eval "$line" + if [ -n "$values[$key]" ]; then + n=0 + while [ -n "$values[${key}${n}]" ]; do n=$(($n + 1)); done + key=$key$n + fi + unset value + unset tag + fi + ;; + esac done + . ${_EXEC}/templates/edit_attendee.sh } case "$1" in @@ -161,6 +271,7 @@ case "$1" in . ${_EXEC}/templates/attendees.css.sh ;; body) + . ${_EXEC}/templates/text_attendee.sh . ${_EXEC}/templates/attendees.html.sh ;; esac