diff --git a/app/MetaGer.php b/app/MetaGer.php
index e209e2991ea92a14133069f0d5677e2936b8bf69..28f031b39fce226798d5068a0166c3f7d7ec8b1c 100644
--- a/app/MetaGer.php
+++ b/app/MetaGer.php
@@ -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.