by-age and by-letter categories
authorChristian Weiske <cweiske@cweiske.de>
Fri, 22 Nov 2019 20:34:26 +0000 (21:34 +0100)
committerChristian Weiske <cweiske@cweiske.de>
Fri, 22 Nov 2019 20:34:26 +0000 (21:34 +0100)
bin/filters.php
bin/import-game-data.php

index adad0d2cafa5c83ce0cb778423fd60ca8ba25b70..07a00bb3a778482e09b1a72f3acf5db6635d19b1 100644 (file)
@@ -1,4 +1,15 @@
 <?php
+function filterByAge($origGames, $age)
+{
+    $filtered = [];
+    foreach ($origGames as $game) {
+        if ($age == $game->contentRating) {
+            $filtered[] = $game;
+        }
+    }
+    return $filtered;
+}
+
 function filterByGenre($origGames, $genre)
 {
     $filtered = [];
@@ -10,6 +21,21 @@ function filterByGenre($origGames, $genre)
     return $filtered;
 }
 
+function filterByLetter($origGames, $letter)
+{
+    $filtered = [];
+    foreach ($origGames as $game) {
+        $gameLetter = strtoupper($game->title{0});
+        if (!preg_match('#^[A-Z]$#', $gameLetter)) {
+            $gameLetter = 'Other';
+        }
+        if ($letter == $gameLetter) {
+            $filtered[] = $game;
+        }
+    }
+    return $filtered;
+}
+
 function filterByPackageNames($origGames, $packageNames)
 {
     $names = array_flip($packageNames);
index 2952aba852330f9dec87a4c601c0948c6b4755d4..66724090fe83792a0bbce20ec54df394c7b7cc48 100755 (executable)
@@ -106,7 +106,7 @@ function buildDiscover(array $games)
     );
     
     $players = [
-        1 => '1 player',
+        //1 => '1 player',
         2 => '2 players',
         3 => '3 players',
         4 => '4 players',
@@ -119,18 +119,20 @@ function buildDiscover(array $games)
         );
     }
 
-    $genres = getAllGenres($games);
-    sort($genres);
-    $genreChunks = array_chunk($genres, 4);
-    $first = true;
-    foreach ($genreChunks as $chunk) {
-        addDiscoverRow(
-            $data, $first ? 'Genres' : '',
-            $chunk
+    $ages = getAllAges($games);
+    natsort($ages);
+    addDiscoverRow($data, 'Content rating', $ages);
+    foreach ($ages as $num => $title) {
+        writeJson(
+            'api/v1/discover-data/' . categoryPath($title) . '.json',
+            buildDiscoverCategory($title, filterByAge($games, $title))
         );
-        $first = false;
     }
 
+    $genres = getAllGenres($games);
+    sort($genres);
+    addChunkedDiscoverRows($data, $genres, 'Genres');
+
     foreach ($genres as $genre) {
         writeJson(
             'api/v1/discover-data/' . categoryPath($genre) . '.json',
@@ -138,6 +140,15 @@ function buildDiscover(array $games)
         );
     }
 
+    $abc = array_merge(range('A', 'Z'), ['Other']);
+    addChunkedDiscoverRows($data, $abc, 'Alphabetical');
+    foreach ($abc as $letter) {
+        writeJson(
+            'api/v1/discover-data/' . categoryPath($letter) . '.json',
+            buildDiscoverCategory($letter, filterByLetter($games, $letter))
+        );
+    }
+
     return $data;
 }
 
@@ -348,6 +359,19 @@ function buildDetails($game)
     ];
 }
 
+function addChunkedDiscoverRows(&$data, $games, $title)
+{
+    $chunks = array_chunk($games, 4);
+    $first = true;
+    foreach ($chunks as $chunk) {
+        addDiscoverRow(
+            $data, $first ? $title : '',
+            $chunk
+        );
+        $first = false;
+    }
+}
+
 function addDiscoverRow(&$data, $title, $games)
 {
     $row = [
@@ -428,7 +452,16 @@ function buildDiscoverGameTile($game)
 
 function categoryPath($title)
 {
-    return str_replace(['/', '\\', ' '], '_', $title);
+    return str_replace(['/', '\\', ' ', '+'], '_', $title);
+}
+
+function getAllAges($games)
+{
+    $ages = [];
+    foreach ($games as $game) {
+        $ages[] = $game->contentRating;
+    }
+    return array_unique($ages);
 }
 
 function getAllGenres($games)