|
11 | 11 | // Set PDO to throw exceptions on error |
12 | 12 | $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); |
13 | 13 |
|
14 | | - // Query to get all projects with dynamic issue counts based on project board status |
15 | | - $query = " |
16 | | - SELECT |
17 | | - p.*, |
18 | | - COALESCE(issue_counts.count_of_issues, 0) as count_of_issues |
19 | | - FROM gh_projects p |
20 | | - LEFT JOIN ( |
| 14 | + // Check if gh_issue_project_status table has data |
| 15 | + $statusTableCheck = $pdo->query("SELECT COUNT(*) as count FROM gh_issue_project_status"); |
| 16 | + $statusTableCount = $statusTableCheck->fetch(PDO::FETCH_ASSOC)['count']; |
| 17 | + |
| 18 | + if ($statusTableCount > 0) { |
| 19 | + // Use gh_issue_project_status table if it has data |
| 20 | + $query = " |
| 21 | + SELECT |
| 22 | + p.*, |
| 23 | + COALESCE(issue_counts.count_of_issues, 0) as count_of_issues |
| 24 | + FROM gh_projects p |
| 25 | + LEFT JOIN ( |
| 26 | + SELECT |
| 27 | + project_id, |
| 28 | + COUNT(DISTINCT gh_node_id) as count_of_issues |
| 29 | + FROM gh_issue_project_status |
| 30 | + GROUP BY project_id |
| 31 | + ) issue_counts ON p.gh_id = issue_counts.project_id |
| 32 | + WHERE p.gh_id != 'UNASSIGNED' |
| 33 | + ORDER BY count_of_issues DESC |
| 34 | + "; |
| 35 | + |
| 36 | + // Add UNASSIGNED project with dynamic count (issues not in any project board) |
| 37 | + $unassignedQuery = " |
| 38 | + SELECT COUNT(*) as count_of_issues |
| 39 | + FROM gh_issues |
| 40 | + WHERE gh_node_id NOT IN (SELECT DISTINCT gh_node_id FROM gh_issue_project_status) |
| 41 | + "; |
| 42 | + } else { |
| 43 | + // Fallback to gh_issues table for project assignments |
| 44 | + $query = " |
21 | 45 | SELECT |
22 | | - project_id, |
23 | | - COUNT(DISTINCT gh_node_id) as count_of_issues |
24 | | - FROM gh_issue_project_status |
25 | | - GROUP BY project_id |
26 | | - ) issue_counts ON p.gh_id = issue_counts.project_id |
27 | | - WHERE p.gh_id != 'UNASSIGNED' |
28 | | - ORDER BY count_of_issues DESC |
29 | | - "; |
| 46 | + p.*, |
| 47 | + COALESCE(issue_counts.count_of_issues, 0) as count_of_issues |
| 48 | + FROM gh_projects p |
| 49 | + LEFT JOIN ( |
| 50 | + SELECT |
| 51 | + gh_project, |
| 52 | + COUNT(*) as count_of_issues |
| 53 | + FROM gh_issues |
| 54 | + WHERE gh_project IS NOT NULL AND gh_project != '' |
| 55 | + GROUP BY gh_project |
| 56 | + ) issue_counts ON p.gh_id = issue_counts.gh_project |
| 57 | + WHERE p.gh_id != 'UNASSIGNED' |
| 58 | + ORDER BY count_of_issues DESC |
| 59 | + "; |
| 60 | + |
| 61 | + // Add UNASSIGNED project with dynamic count (issues not assigned to any project) |
| 62 | + $unassignedQuery = " |
| 63 | + SELECT COUNT(*) as count_of_issues |
| 64 | + FROM gh_issues |
| 65 | + WHERE gh_project IS NULL OR gh_project = '' |
| 66 | + "; |
| 67 | + } |
| 68 | + |
30 | 69 | $result = $pdo->query($query); |
31 | 70 | $projects = $result->fetchAll(PDO::FETCH_ASSOC); |
32 | 71 |
|
33 | | - // Add UNASSIGNED project with dynamic count (issues not in any project board) |
34 | | - $unassignedQuery = " |
35 | | - SELECT COUNT(*) as count_of_issues |
36 | | - FROM gh_issues |
37 | | - WHERE gh_node_id NOT IN (SELECT DISTINCT gh_node_id FROM gh_issue_project_status) |
38 | | - "; |
39 | 72 | $unassignedResult = $pdo->query($unassignedQuery); |
40 | 73 | $unassignedCount = $unassignedResult->fetch(PDO::FETCH_ASSOC)['count_of_issues']; |
41 | 74 |
|
|
0 commit comments