]> git.plutz.net Git - serve0/blobdiff - multitag.sh
avoid multiple reordering of tags
[serve0] / multitag.sh
index 888ff9d9a18bcc7f29d96139ab9cdded84a7bfb1..12117cdf86ea852b7ea430a5aedd00c9f8eb4969 100755 (executable)
@@ -1,12 +1,18 @@
 #!/bin/sh
 
 . "$_EXEC/db_meta.sh"
+. "$_EXEC/cgilite/session.sh" nocookie
+. "$_EXEC/widgets.sh"
 
 newtags=''
 for tn in $(seq 1 $(POST_COUNT tag)); do
   newtags="$(POST tag $tn)${BR}${newtags}"
 done
-newtags="$(POST newtag |tr -d '\r' |tr , '\n')${BR}${newtags}"
+newtags="$(POST newtagn |tr -d '\r' |tr , '\n')${BR}${newtags}"
+
+if [ "$(POST makegroup)" = true ]; then
+  group="$(timeid)"
+fi
 
 while [ "${newtags#${BR}}" != "${newtags}" ]; do newtags="${newtags#${BR}}"; done
 while [ "${newtags%${BR}}" != "${newtags}" ]; do newtags="${newtags%${BR}}"; done
@@ -36,5 +42,15 @@ for select in $(seq 1 $(POST_COUNT select)); do
   fi
   tags="${tags#,}"; tags="${tags%,}"
 
-  update_meta "$META_NAME" tags="${tags}"
+  if [ "$group" ]; then
+    update_meta "$META_NAME" tags="${tags}" group="${group}"
+  else
+    update_meta "$META_NAME" tags="${tags}"
+  fi
 done
+
+( if [ $(POST_COUNT select) -gt 0 ]; then
+    taglist >"$c_tags.$$"
+    mv -- "$c_tags.$$" "$c_tags"
+  fi &
+) &