mirror of
https://github.com/ceratic/MediaCollectorLibary.git
synced 2026-05-13 23:56:46 +02:00
basic filter D:
This commit is contained in:
@@ -83,7 +83,7 @@ class TvShow extends Model
|
||||
/**
|
||||
* Get total count with optional search
|
||||
*/
|
||||
public static function getTotalCount(\PDO $pdo, string $search = ''): int
|
||||
public static function getTotalCount(\PDO $pdo, string $search = '', array $genres = [], array $years = []): int
|
||||
{
|
||||
$sql = "SELECT COUNT(*) as count FROM tv_shows t JOIN sources s ON t.source_id = s.id";
|
||||
$params = [];
|
||||
@@ -93,15 +93,38 @@ class TvShow extends Model
|
||||
$params['search'] = "%{$search}%";
|
||||
}
|
||||
|
||||
if (!empty($genres)) {
|
||||
$placeholders = [];
|
||||
foreach ($genres as $index => $genre) {
|
||||
$placeholders[] = ":genre_{$index}";
|
||||
$params["genre_{$index}"] = $genre;
|
||||
}
|
||||
$whereClause = !empty($search) ? " AND" : " WHERE";
|
||||
$sql .= $whereClause . " t.genre IN (" . implode(',', $placeholders) . ")";
|
||||
}
|
||||
|
||||
if (!empty($years)) {
|
||||
$placeholders = [];
|
||||
foreach ($years as $index => $year) {
|
||||
$placeholders[] = ":year_{$index}";
|
||||
$params["year_{$index}"] = $year;
|
||||
}
|
||||
$whereClause = (!empty($search) || !empty($genres)) ? " AND" : " WHERE";
|
||||
$sql .= $whereClause . " YEAR(first_air_date) IN (" . implode(',', $placeholders) . ")";
|
||||
}
|
||||
|
||||
$stmt = $pdo->prepare($sql);
|
||||
$stmt->execute($params);
|
||||
foreach ($params as $key => $value) {
|
||||
$stmt->bindValue(":{$key}", $value);
|
||||
}
|
||||
$stmt->execute();
|
||||
return (int) $stmt->fetch()['count'];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get all TV shows with pagination and optional search
|
||||
*/
|
||||
public static function getAllWithPagination(\PDO $pdo, int $page, int $perPage, string $search = ''): array
|
||||
public static function getAllWithPagination(\PDO $pdo, int $page, int $perPage, string $search = '', array $genres = [], array $years = []): array
|
||||
{
|
||||
$offset = ($page - 1) * $perPage;
|
||||
|
||||
@@ -117,6 +140,26 @@ class TvShow extends Model
|
||||
$params['search'] = "%{$search}%";
|
||||
}
|
||||
|
||||
if (!empty($genres)) {
|
||||
$placeholders = [];
|
||||
foreach ($genres as $index => $genre) {
|
||||
$placeholders[] = ":genre_{$index}";
|
||||
$params["genre_{$index}"] = $genre;
|
||||
}
|
||||
$whereClause = !empty($search) ? " AND" : " WHERE";
|
||||
$sql .= $whereClause . " t.genre IN (" . implode(',', $placeholders) . ")";
|
||||
}
|
||||
|
||||
if (!empty($years)) {
|
||||
$placeholders = [];
|
||||
foreach ($years as $index => $year) {
|
||||
$placeholders[] = ":year_{$index}";
|
||||
$params["year_{$index}"] = $year;
|
||||
}
|
||||
$whereClause = (!empty($search) || !empty($genres)) ? " AND" : " WHERE";
|
||||
$sql .= $whereClause . " YEAR(first_air_date) IN (" . implode(',', $placeholders) . ")";
|
||||
}
|
||||
|
||||
$sql .= " ORDER BY t.title ASC LIMIT :limit OFFSET :offset";
|
||||
|
||||
$stmt = $pdo->prepare($sql);
|
||||
@@ -259,9 +302,8 @@ public function recordView(): bool
|
||||
public static function getAvailableGenres(\PDO $pdo): array
|
||||
{
|
||||
$stmt = $pdo->query("
|
||||
SELECT DISTINCT TRIM(value) as genre
|
||||
FROM tv_shows,
|
||||
json_each('[\"' || REPLACE(genre, ',', '\",\"') || '\"]')
|
||||
SELECT DISTINCT genre
|
||||
FROM tv_shows
|
||||
WHERE genre IS NOT NULL AND genre != ''
|
||||
ORDER BY genre
|
||||
");
|
||||
@@ -274,7 +316,7 @@ public static function getAvailableGenres(\PDO $pdo): array
|
||||
public static function getAvailableYears(\PDO $pdo): array
|
||||
{
|
||||
$stmt = $pdo->query("
|
||||
SELECT DISTINCT strftime('%Y', first_air_date) as year
|
||||
SELECT DISTINCT YEAR(first_air_date) as year
|
||||
FROM tv_shows
|
||||
WHERE first_air_date IS NOT NULL
|
||||
ORDER BY year DESC
|
||||
|
||||
Reference in New Issue
Block a user