diff --git a/lib/classes/caption/Field/Value.php b/lib/classes/caption/Field/Value.php
index ec492ee7bb..e15826a05d 100644
--- a/lib/classes/caption/Field/Value.php
+++ b/lib/classes/caption/Field/Value.php
@@ -353,72 +353,55 @@ class caption_Field_Value implements cache_cacheableInterface
return $value;
}
+ // ---------------- new code ----------------------
$cleanvalue = str_replace(array("", "", "'"), array("", "", "'"), $value);
- $fvalue = $value;
-
- $cleanvalue = str_replace(array("", "", "'"), array("", "", "'"), $fvalue);
-
list($term_noacc, $context_noacc) = $this->splitTermAndContext($cleanvalue);
$term_noacc = $this->app['unicode']->remove_indexer_chars($term_noacc);
$context_noacc = $this->app['unicode']->remove_indexer_chars($context_noacc);
+
+ // find all synonyms in all related branches
+ $q = "(" . $tbranch . ")//sy[@w='" . $term_noacc . "'";
if ($context_noacc) {
- $q = "//sy[@w='" . $term_noacc . "' and @k='" . $context_noacc . "']";
+ $q .= " and @k='" . $context_noacc . "']";
} else {
- $q = "//sy[@w='" . $term_noacc . "' and not(@k)]";
+ $q .= " and not(@k)]";
}
- $qjs = $link = "";
+ $q .= "/../sy";
- // loop on each linked branch for field
- foreach ($DOM_branchs as $DOM_branch) {
- $nodes = $XPATH_thesaurus->cache_query($q, $DOM_branch);
- $lngfound = false;
- foreach ($nodes as $node) {
- if ($node->getAttribute("lng") == $this->app['locale.I18n']) {
- // le terme est dans la bonne langue, on le rend cliquable
- list($term, $context) = $this->splitTermAndContext($fvalue);
- $term = str_replace(array("", ""), array("", ""), $term);
- $context = str_replace(array("", ""), array("", ""), $context);
- $qjs = $term;
- if ($context) {
- $qjs .= " [" . $context . "]";
- }
- $link = $fvalue;
+ $nodes = $XPATH_thesaurus->query($q);
- $lngfound = true;
- break;
- }
-
- $synonyms = $XPATH_thesaurus->query("sy[@lng='" . $this->app['locale.I18n'] . "']", $node->parentNode);
- foreach ($synonyms as $synonym) {
- $k = $synonym->getAttribute("k");
- if ($synonym->getAttribute("w") != $term_noacc || $k != $context_noacc) {
- $link = $qjs = $synonym->getAttribute("v");
- $lngfound = true;
- break;
- }
- }
-
- }
- if (! $lngfound) {
- list($term, $context) = $this->splitTermAndContext($fvalue);
- $term = str_replace(array("", ""), array("", ""), $term);
- $context = str_replace(array("", ""), array("", ""), $context);
- $qjs = $term;
- if ($context) {
- $qjs .= " [" . $context . "]";
- }
- $link = $fvalue;
+ // loop on every sy found
+ $bestnode = null;
+ $bestnote = 0;
+ foreach ($nodes as $node) {
+ $note = 0;
+ $note += ($node->getAttribute("lng") == $this->app['locale.I18n']) ? 4 : 0;
+ $note += ($node->getAttribute("w") == $term_noacc) ? 2 : 0;
+ if($context_noacc != "")
+ $note += ($node->getAttribute("k") == $context_noacc) ? 1 : 0;
+ if($note > $bestnote)
+ {
+ $bestnote = $note;
+ $bestnode = $node;
}
}
+ if($bestnode)
+ {
+ list($term, $context) = $this->splitTermAndContext($value);
+ $term = str_replace(array("", ""), array("", ""), $term);
+ $context = str_replace(array("", ""), array("", ""), $context);
+ $qjs = $term;
+ if ($context) {
+ $qjs .= " [" . $context . "]";
+ }
- if ($qjs) {
$value = "get_sbas_id() . "','"
. str_replace("'", "\'", $qjs)
. "', '"
. str_replace("'", "\'", $this->databox_field->get_name())
. "');return(false);\">"
- . $link
+ . $bestnode->getAttribute('v')
. "";
}