Commit 211d16ae authored by Karl Hasselbring's avatar Karl Hasselbring
Browse files

Der Suchfokus wird jetzt automatisch angepasst, falls ein Nutzer mit...

Der Suchfokus wird jetzt automatisch angepasst, falls ein Nutzer mit angepassten Einstellungen aber allen Suchmaschinen eines Suchfokus ausgewählt sucht.
parent 2917f647
......@@ -297,10 +297,9 @@ class MetaGer
$enabledSearchengines = [];
$overtureEnabled = FALSE;
$countSumas = 0;
$sumas = $xml->xpath("suma");
if($this->fokus === "angepasst")
{
$sumas = $xml->xpath("suma");
foreach($sumas as $suma)
{
if($request->has($suma["name"])
......@@ -325,7 +324,6 @@ class MetaGer
}
}
}else{
$sumas = $xml->xpath("suma");
foreach($sumas as $suma){
$types = explode(",",$suma["type"]);
if(in_array($this->fokus, $types)
......@@ -429,18 +427,20 @@ class MetaGer
$this->sockets[$tmp->name] = $tmp->fp;
}
# Alternativ
# Hier wird direkt eine Liste der Fokustypen erstellt, die bei der Suche verwendet werden: [0] => [web, nachrichten]
if($engine["name"] !== "overtureAds") {
/*if($engine["name"] !== "overtureAds") {
$type = explode(",", $engine["type"]);
if(!$type[0] == "") {
$typeslist[$counter++] = $type;
}
}
}*/
}
# Alternativ
# Jetzt wird geguckt, ob diese Liste überhaupt Typen enthält und für jeden Typen des ersten Eintrags (oder späteren falls dieser "" ist) wird geguckt, ob sich dieser Typ in allen folgenden Einträgen finden lässt. Diese Einträge sind nie "web", da diese Suche meist eh auch möglich ist und ohnehin wie die angepasste Suche funktioniert. Am Ende wird geguckt ob es einen Typen gab, der in allen Elementen enthalten ist. Dieser wird als Fokus gesetzt.
if(!empty($typeslist)) {
/*if(!empty($typeslist)) {
foreach($typeslist as $matchTypeSearch) {
if(!empty($matchTypeSearch) && $matchTypeSearch[0] !== "") {
$toMatch = $matchTypeSearch;
......@@ -467,6 +467,58 @@ class MetaGer
if($matchedType !== "") {
$this->fokus = $matchedType;
}
}*/
# Jetzt werden noch alle Kategorien der Settings durchgegangen und die jeweils enthaltenen namen der Suchmaschinen gespeichert.
$foki = [];
foreach($sumas as $suma)
{
if( (!isset($suma['disabled']) || $suma['disabled'] === "") && ( !isset($suma['userSelectable']) || $suma['userSelectable']->__toString() === "1") )
{
if( isset($suma['type']) )
{
$f = explode(",", $suma['type']->__toString());
foreach($f as $tmp)
{
$name = $suma['name']->__toString();
$foki[$tmp][$suma['name']->__toString()] = $name;
}
}else
{
$name = $suma['name']->__toString();
$foki["andere"][$suma['name']->__toString()] = $name;
}
}
}
# Es werden auch die Namen der aktuell aktiven Suchmaschinen abgespeichert.
$realEngNames = [];
foreach($enabledSearchengines as $realEng) {
$nam = $realEng["name"]->__toString();
if($nam !== "qualigo" && $nam !== "overtureAds") {
$realEngNames[] = $nam;
}
}
# Anschließend werden diese beiden Listen verglichen (jeweils eine der Fokuslisten für jeden Fokus), um herauszufinden ob sie vielleicht identisch sind. Ist dies der Fall, so hat der Nutzer anscheinend Suchmaschinen eines kompletten Fokus eingestellt. Der Fokus wird dementsprechend angepasst.
foreach($foki as $fok => $engs) {
$isFokus = true;
$fokiEngNames = [];
foreach($engs as $eng) {
$fokiEngNames[] = $eng;
}
foreach($fokiEngNames as $fen) {
if(!in_array($fen, $realEngNames)) {
$isFokus = false;
}
}
foreach($realEngNames as $ren) {
if(!in_array($ren, $fokiEngNames)) {
$isFokus = false;
}
}
if($isFokus) {
$this->fokus = $fok;
}
}
# Nun passiert ein elementarer Schritt.
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment