first implementation of "selected tag condition"
authorAndreas Unterkircher <unki@netshadow.at>
Sat, 9 Jun 2007 09:04:07 +0000 (09:04 +0000)
committerAndreas Unterkircher <unki@netshadow.at>
Sat, 9 Jun 2007 09:04:07 +0000 (09:04 +0000)
git-svn-id: file:///var/lib/svn/phpfspot/trunk@74 fa6a889d-dae6-447d-9e79-4ba9a3039384

phpfspot.class.php
phpfspot.js
rpc.php
templates/tags.tpl

index f405626dc4f573f3f922f427e4512ed56457ead8..7bccc9e8672489dd294d2c538c9ba1dc03e00230 100644 (file)
@@ -27,6 +27,11 @@ class PHPFSPOT {
 
       $this->get_tags();
 
 
       $this->get_tags();
 
+      session_start();
+
+      if(!isset($_SESSION['tag_condition']))
+         $_SESSION['tag_condition'] = 'or';
+
    } // __construct()
 
    public function __destruct()
    } // __construct()
 
    public function __destruct()
@@ -37,6 +42,7 @@ class PHPFSPOT {
    public function show()
    {
       $this->tmpl->assign('page_title', $this->cfg->page_title);
    public function show()
    {
       $this->tmpl->assign('page_title', $this->cfg->page_title);
+      $this->tmpl->assign('current_condition', $_SESSION['tag_condition']);
       $this->tmpl->show("index.tpl");
 
    } // show()
       $this->tmpl->show("index.tpl");
 
    } // show()
@@ -192,14 +198,49 @@ class PHPFSPOT {
          foreach($_SESSION['selected_tags'] as $tag)
             $selected.= $tag .",";
          $selected = substr($selected, 0, strlen($selected)-1);
          foreach($_SESSION['selected_tags'] as $tag)
             $selected.= $tag .",";
          $selected = substr($selected, 0, strlen($selected)-1);
-         $result = $this->db->db_query("
-            SELECT DISTINCT photo_id
-               FROM photo_tags pt
-            INNER JOIN photos p
-               ON p.id=pt.photo_id
-            WHERE pt.tag_id IN (". $selected .")
-            ORDER BY p.time ASC
-         ");
+
+         if($_SESSION['tag_condition'] == 'or') {
+            $result = $this->db->db_query("
+               SELECT DISTINCT photo_id
+                  FROM photo_tags pt
+               INNER JOIN photos p
+                  ON p.id=pt.photo_id
+               WHERE pt.tag_id IN (". $selected .")
+               ORDER BY p.time ASC
+            ");
+            while($row = $this->db->db_fetch_object($result)) {
+               array_push($tagged_photos, $row['photo_id']);
+            }
+         }
+         elseif($_SESSION['tag_condition'] == 'and') {
+            $result = $this->db->db_query("
+               SELECT DISTINCT photo_id, tag_id
+                  FROM photo_tags pt
+               INNER JOIN photos p
+                  on p.id=pt.photo_id
+               WHERE pt.tag_id IN (". $selected .")
+               ORDER BY p.time ASC
+            ");
+
+            /* now we need to check if each object fulfills the condition
+               and has all the selected tags assigned
+            */
+            $match_object = Array();
+            $matches_needed = count($_SESSION['selected_tags']);
+            while($row = $this->db->db_fetch_object($result)) {
+               /* set the counter for this object */
+               if(!isset($match_object[$row['photo_id']]))
+                  $match_object[$row['photo_id']] = $matches_needed;
+               
+               /* we have a match? decrement the counter */
+               if(in_array($row['tag_id'], $_SESSION['selected_tags']))
+                  $match_object[$row['photo_id']]--;
+
+               /* if the object has all necessary tags, add it to the result */
+               if($match_object[$row['photo_id']] == 0)
+                  array_push($tagged_photos, $row['photo_id']);
+            }
+         }
       }
       else {
          $result = $this->db->db_query("
       }
       else {
          $result = $this->db->db_query("
@@ -209,10 +250,9 @@ class PHPFSPOT {
                ON p.id=pt.photo_id
             ORDER BY p.time ASC
          ");
                ON p.id=pt.photo_id
             ORDER BY p.time ASC
          ");
-      }
-
-      while($row = $this->db->db_fetch_object($result)) {
-         array_push($tagged_photos, $row['photo_id']);
+         while($row = $this->db->db_fetch_object($result)) {
+            array_push($tagged_photos, $row['photo_id']);
+         }
       }
 
       return $tagged_photos;
       }
 
       return $tagged_photos;
@@ -434,6 +474,12 @@ class PHPFSPOT {
 
    } // setMD5()
 
 
    } // setMD5()
 
+   public function setTagCondition($mode)
+   {
+      $_SESSION['tag_condition'] = $mode;
+
+   } // setTagCondition()
+
 }
 
 ?>
 }
 
 ?>
index c691b55949c62ddc83e37b421972a05a47acc339..b7c6794b5eaa2c5af44be80caa32bf36f79fba83 100644 (file)
@@ -23,6 +23,10 @@ function Tags(mode, id)
    else if(mode == "reset") {
       HTML_AJAX.grab('rpc.php?action=resettags');
    }
    else if(mode == "reset") {
       HTML_AJAX.grab('rpc.php?action=resettags');
    }
+   else if(mode == "condition") {
+      setCheckedValue(id, id.value);
+      HTML_AJAX.grab('rpc.php?action=tagcondition&mode=' + id.value);
+   }
    
    refreshAvailableTags();
    refreshSelectedTags();
    
    refreshAvailableTags();
    refreshSelectedTags();
@@ -70,3 +74,23 @@ function click(object)
 
 }
 
 
 }
 
+// set the radio button with the given value as being checked
+// do nothing if there are no radio buttons
+// if the given value does not exist, all the radio buttons
+// are reset to unchecked
+function setCheckedValue(condition, value) {
+
+   var count = condition.length;
+   if(count == undefined) {
+      condition.checked = (condition.value == value.toString());
+      return;
+   }
+   for(var i = 0; i < count; i++) {
+      condition[i].checked = false;
+      if(condition[i].value == value.toString()) {
+         condition[i].checked = true;
+      }
+   }
+}
+
+
diff --git a/rpc.php b/rpc.php
index 4599e11c8603598614ac292111bb499abc112276..ef1be6a42989668cbf5883dd23ffcf3398afca0c 100644 (file)
--- a/rpc.php
+++ b/rpc.php
@@ -73,6 +73,11 @@ class PHPFSPOT_RPC {
             $fspot->resetTags();
             break;
 
             $fspot->resetTags();
             break;
 
+         case 'tagcondition':
+
+            $fspot->setTagCondition($_GET['mode']);
+            break;
+
          case 'show_photo_index':
 
             $fspot->showPhotoIndex();
          case 'show_photo_index':
 
             $fspot->showPhotoIndex();
index 812b36a38d5b250ecefb55087beb194df270c261..99c8b90784bcabf03267b05e362afa293ac95dc0 100644 (file)
   </td>
  </tr>
  <tr>
   </td>
  </tr>
  <tr>
-  <td style="vertical-align: middle; text-decoration: underline;">
-   <img src="resources/selected_tags.png" />Selected Tags:
+  <td>
+   <table style="width: 100%;">
+    <tr>
+     <td style="vertical-align: bottom; text-decoration: underline;">
+      <img src="resources/selected_tags.png" />Selected Tags:
+     </td>
+     <td style="vertical-align: bottom;">
+      &nbsp;
+      Condition:
+      <input type="radio" name="condition" value="or" onclick="Tags('condition', this);" {if $current_condition == "or" } checked="checked" { /if } />OR
+      <input type="radio" name="condition" value="and" onclick="Tags('condition', this);" {if $current_condition == "and" } checked="checked" { /if } />AND
+     </td>
+    </tr>
+   </table>
   </td>
  </tr>
  <tr>
   </td>
  </tr>
  <tr>