X-Git-Url: https://git.plutz.net/?p=confetti;a=blobdiff_plain;f=pages%2Fcards.sh;h=50fee63b76c70040b1a776172e19d3385337b5f4;hp=f2675ba0f7a9301baa88852376c9943791d2335b;hb=aedb6776919b351df7df7c310c238c41317ddc44;hpb=69e661b5c8ec195bd3c4998a623a60607b47059e diff --git a/pages/cards.sh b/pages/cards.sh index f2675ba..50fee63 100755 --- a/pages/cards.sh +++ b/pages/cards.sh @@ -19,6 +19,9 @@ [ -z "${_GET[order]}" ] && _GET[order]="firstname" +BR=' +' + 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")" @@ -26,6 +29,10 @@ listcourses() { done |sort |sed -r 's:^.*\t(.*/)([^/]+)$:\2:' } +list_hi_companies(){ + sed -rn 's;^X-HEALTH-INSURANCE:([^\;]+)\;.*$;\1;p' ${_DATA}/vcard/*vcf +} + listcards() { case "${_GET[filtertype]}" in any) @@ -78,124 +85,51 @@ listcards() { vcf_parse() { tr -d '\n' <"$1" |sed -r 's:\r ::g;s:\r:\n:g' \ | sed -rn ' - s:^PHOTO:001 PHOTO:p; - s:^X-MS-CARDPICTURE:001 PHOTO:p; - s:^LOGO:002 LOGO:p; - s:^FN:003 FN:p; - s:^N[\:;]:004 &:p - s:^NICKNAME:005 NICKNAME:p; - s:^SOUND:006 SOUND:p; - s:^GENDER:007 GENDER:p; - s:^X-GENDER:007 GENDER:p; - s:^KIND:008 KIND:p; - s:^TITLE:009 TITLE:p; - s:^ROLE:010 ROLE:p; - s:^ORG:011 ORG:p; - s:^MEMBER:012 MEMBER:p; - s:^CATEGORIES:013 CATEGORIES:p; - s:^ANNIVERSARY:014 ANNIVERSARY:p; - s:^X-ANNIVERSARY:014 ANNIVERSARY:p; - s:^X-EVOLUTION-ANNIVERSARY:014 ANNIVERSARY:p; - s:^X-KADDRESSBOOK-X-Anniversary:014 ANNIVERSARY:p; - s:^BDAY:015 BDAY:p; - s:^EMAIL:016 EMAIL:p; - s:^TEL:017 TEL:p; - s:^IMPP:018 IMPP:p; - s:^X-AIM(;[^"\:]+|;"[^"]+")*\:(.*)$:018 IMPP\1\:aim\:\2:p; - s:^X-ICQ(;[^"\:]+|;"[^"]+")*\:(.*)$:018 IMPP\1\:aim\:\2:p; - s:^X-GOOGLE-TALK(;[^"\:]+|;"[^"]+")*\:(.*)$:018 IMPP\1\:xmpp\:\2:p; - s:^X-JABBER(;[^"\:]+|;"[^"]+")*\:(.*)$:018 IMPP\1\:xmpp\:\2:p; - s:^X-MSN(;[^"\:]+|;"[^"]+")*\:(.*)$:018 IMPP\1\:msn\:\2:p; - s:^X-YAHOO(;[^"\:]+|;"[^"]+")*\:(.*)$:018 IMPP\1\:ymsgr\:\2:p; - s:^X-SIP(;[^"\:]+|;"[^"]+")*\:(sip\:)?(.*)$:018 IMPP\1\:sip\:\3:p; - s:^ADR:019 ADR:p; - s:^LABEL(;[^"\:]+|;"[^"]+")*\:(.*)$:019 ADR;LABEL="\2"\1\::p; - s:^URL:021 URL:p; - s:^X-EVOLUTION-BLOG-URL:021 URL:p; - s:^LANG:022 LANG:p; - s:^NOTE:023 NOTE:p; - s:^UID:026 UID:p; + s:^X-MS-CARDPICTURE:PHOTO:p; + s:^X-GENDER:GENDER:p; + s:^X-ANNIVERSARY:ANNIVERSARY:p; + s:^X-EVOLUTION-ANNIVERSARY:ANNIVERSARY:p; + s:^X-KADDRESSBOOK-X-Anniversary:ANNIVERSARY:p; + s:^X-AIM(;[^"\:]+|;"[^"]+")*\:(.*)$:IMPP\1\:aim\:\2:p; + s:^X-ICQ(;[^"\:]+|;"[^"]+")*\:(.*)$:IMPP\1\:aim\:\2:p; + s:^X-GOOGLE-TALK(;[^"\:]+|;"[^"]+")*\:(.*)$:IMPP\1\:xmpp\:\2:p; + s:^X-JABBER(;[^"\:]+|;"[^"]+")*\:(.*)$:IMPP\1\:xmpp\:\2:p; + s:^X-MSN(;[^"\:]+|;"[^"]+")*\:(.*)$:IMPP\1\:msn\:\2:p; + s:^X-YAHOO(;[^"\:]+|;"[^"]+")*\:(.*)$:IMPP\1\:ymsgr\:\2:p; + s:^X-SIP(;[^"\:]+|;"[^"]+")*\:(sip\:)?(.*)$:IMPP\1\:sip\:\3:p; + s:^LABEL(;[^"\:]+|;"[^"]+")*\:(.*)$:ADR;LABEL="\2"\1\::p; + s:^X-EVOLUTION-BLOG-URL:URL:p; - s:^RELATED:025 RELATED:p; - s:^AGENT:025 RELATED\;TYPE=agent:p; - s:^X-ASSISTANT:025 RELATED\;TYPE=assistant;VALUE=text:p; - s:^X-EVOLUTION-ASSISTANT:025 RELATED\;TYPE=assistant;VALUE=text:p; - s:^X-KADDRESSBOOK-X-AssistantsName:025 RELATED\;TYPE=assistant;VALUE=text:p; - s:^X-MANAGER:025 RELATED\;TYPE=manager;VALUE=text:p; - s:^X-EVOLUTION-MANAGER:025 RELATED\;TYPE=manager;VALUE=text:p; - s:^X-KADDRESSBOOK-X-ManagersName:025 RELATED\;TYPE=manager;VALUE=text:p; - s:^X-SPOUSE:025 RELATED\;TYPE=spouse;VALUE=text:p; - s:^X-EVOLUTION-SPOUSE:025 RELATED\;TYPE=spouse;VALUE=text:p; - s:^X-KADDRESSBOOK-X-SpouseName:025 RELATED\;TYPE=spouse;VALUE=text:p; + s:^AGENT:RELATED\;TYPE=agent:p; + s:^X-ASSISTANT:RELATED\;TYPE=assistant;VALUE=text:p; + s:^X-EVOLUTION-ASSISTANT:RELATED\;TYPE=assistant;VALUE=text:p; + s:^X-KADDRESSBOOK-X-AssistantsName:RELATED\;TYPE=assistant;VALUE=text:p; + s:^X-MANAGER:RELATED\;TYPE=manager;VALUE=text:p; + s:^X-EVOLUTION-MANAGER:RELATED\;TYPE=manager;VALUE=text:p; + s:^X-KADDRESSBOOK-X-ManagersName:RELATED\;TYPE=manager;VALUE=text:p; + s:^X-SPOUSE:RELATED\;TYPE=spouse;VALUE=text:p; + s:^X-EVOLUTION-SPOUSE:RELATED\;TYPE=spouse;VALUE=text:p; + s:^X-KADDRESSBOOK-X-SpouseName:RELATED\;TYPE=spouse;VALUE=text:p; - s:^BEGIN.*$:000 &:p; - s:^CALADRURI.*$::; - s:^CALURI.*$::; - s:^CLASS.*$::; - s:^CLIENTPIDMAP.*$::; - s:^END.*$:100 &:p; - s:^FBURL.*$::; - s:^GEO.*$::; - s:^MAILER.*$::; - s:^NAME.*$::; - s:^PRODID.*$::; - s:^PROFILE.*$::; - s:^REV.*$::; - s:^SORT-STRING.*$::; - s:^SOURCE.*$::; - s:^TZ.*$::; - s:^VERSION.*$:000 VERSION\:4.0:p; - s:^XML.*$::; - - s:^([A-Z].*)$:024 \1:p; + s:^([A-Z].*)$:\1:p; ' \ - |sort |while read -r line; do - case "$line" in - 00[012]*) - echo -E "$line" - ;; - 003*) - fn=$(echo -E "$line" |sed -r 's:^[0-9]{3} ([^;\:]+)(;[^"\:]+|;"[^"]+")*\:(.*)$:\3:g' |tr -d '\r') - ;; - 004*) - n=$(echo -E "$line" \ - |sed -rn 's:^([0-9]{3} )([^;\:]+)(;[^"\:]+|;"[^"]+")*\:([^;]*)(\;[^;]*)(\;[^;]*)?(\;[^;]*)?(\;[^;]*)?$:\7 \5 \6 \4 \8:gp' \ - |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" \ - || echo -E "003 FN:$nick" - echo -E "$line" - cat - ;; - esac - done |tr -d '\r' \ - | sed -r 's:^[0-9]{3} ([^;\:]+)(;[^"\:]+|;"[^"]+")*\:(.*)$:key="\1"\nvalue="\3"\ntag=\2:g' \ + | sed -r 's:^([^;\:]+)(;[^"\:]+|;"[^"]+")*\:(.*)$:key="\1"\nvalue="\3"\ntag=\2:g' \ | while read -r line; do case "$line" in - key=*) echo -E "$line" + key=*) printf %s\\n "$line" ;; - value=*) echo -E "$line" + value=*) printf %s\\n "${line}" ;; tag=*) ot='' - echo -E "$line" \ + printf %s "$line" \ | sed -r 's:^tag=::;s:\;([A-Z+_-]+="[^"]+"|[A-Z+_-]+=[^\;]+):\n\1:g;' \ | sed -r 's:([A-Z+_-]+)="?(.*)"?:tag\[\1\]="\2":g' \ | sed -r '/^ *$/d' \ | sort |while read -r tag; do - nt="$(echo -E "$tag" |sed -r 's:^tag\[([A-Z+_-]+)\]="(.*)"$:\1:')" - nv="$(echo -E "$tag" |sed -r 's:^tag\[([A-Z+_-]+)\]="(.*)"$:\2:')" + nt="$(printf %s "$tag" |sed -r 's:^tag\[([A-Z+_-]+)\]="(.*)"$:\1:')" + nv="$(printf %s "$tag" |sed -r 's:^tag\[([A-Z+_-]+)\]="(.*)"$:\2:')" [ "$nt" = "$ot" ] && vl="$nv,$vl" || vl="$nv" - echo -E "tag[$nt]=\"$vl\"" + printf %s\\n "tag[$nt]=\"$vl\"" ot="$nt" done ;; @@ -223,7 +157,7 @@ view_card() { #Parameter: Cardfile if [ -z "$key" ]; then eval "$line" else - values[$key]="$value" + values[$key]="${value//\\r\\n/$BR}" for t in ${(k)tag}; do tags[${key}_$t]="$tag[$t]" done @@ -261,7 +195,7 @@ edit_card() { #Parameter: Cardfile if [ -z "$key" ]; then eval "$line" else - [ -n "$value" ] && values[$key]="$value" || values[$key]='\r' + [ -n "$value" ] && values[$key]="${value//\\r\\n/$BR}" || values[$key]='\r' for t in ${(k)tag}; do tags[${key}_$t]="$tag[$t]" done