diff --git a/src/CodeKeeper/keeperFunc/getProjectInfo.cpp b/src/CodeKeeper/keeperFunc/getProjectInfo.cpp index 75da2f1a..458d6f5e 100644 --- a/src/CodeKeeper/keeperFunc/getProjectInfo.cpp +++ b/src/CodeKeeper/keeperFunc/getProjectInfo.cpp @@ -135,29 +135,27 @@ QString MainWindow::getRepositoryData(QString git_url, QTableWidget *table) createdAt = obj["created_at"].toString(); QDateTime createdDate = QDateTime::fromString(createdAt, Qt::ISODate); createdAt = createdDate.toString("dd MMM yyyy hh:mm"); - + openIssues = QString::number(obj["open_issues"].toInt()); // repoData += " \n Watchers: " + QString::number(obj["watchers"].toInt()) + " "; forks = QString::number(obj["forks"].toInt()); lang = obj["language"].toString(); - - + stars = QString::number(obj["stargazers_count"].toInt()); - + qint64 size = obj["size"].toDouble(); repoSize = formatFileSize(size); - if (obj.contains("license")) { QJsonObject licenseObj = obj["license"].toObject(); if (licenseObj.contains("name")) { - license = licenseObj["name"].toString() + " "; + license = licenseObj["name"].toString() + " "; } else { - qDebug() << "License not found"; + qDebug() << "License not found"; } } else { - qDebug() << "License not found"; + qDebug() << "License not found"; } QUrl commitUrl("https://api.github.com/repos/" + repo + "/commits"); @@ -227,7 +225,6 @@ QString MainWindow::getRepositoryData(QString git_url, QTableWidget *table) totalDownloads = QString::number(iTotalDownloads); - // Release info QUrl releasesUrl("https://api.github.com/repos/" + repo + "/releases/latest"); releasesUrl.setQuery(query); @@ -252,7 +249,6 @@ QString MainWindow::getRepositoryData(QString git_url, QTableWidget *table) QJsonObject releasesObj = releasesDoc.object(); qDebug() << releasesDoc; - release = releasesObj["name"].toString(); dateStr = releasesObj["published_at"].toString(); @@ -267,8 +263,8 @@ QString MainWindow::getRepositoryData(QString git_url, QTableWidget *table) table->setColumnCount(2); table->setShowGrid(false); - table->setColumnWidth(0, 195); - table->setColumnWidth(1, 195); + table->setColumnWidth(0, 190); + table->setColumnWidth(1, 190); table->setRowHeight(0, 25); table->setRowHeight(1, 25); @@ -355,8 +351,6 @@ QString MainWindow::getRepositoryData(QString git_url, QTableWidget *table) table->item(i, 0)->setTextAlignment(Qt::AlignCenter); } - - for (int row = 0; row < table->rowCount(); ++row) { for (int col = 0; col < table->columnCount(); ++col) { QTableWidgetItem *item = table->item(row, col); @@ -368,3 +362,51 @@ QString MainWindow::getRepositoryData(QString git_url, QTableWidget *table) return repoData; } + +QString MainWindow::getProjectIssues(QString git_url) +{ + int maxLength = 120; + QString prefix = "https://github.com/"; + QString repo = git_url.replace(prefix, ""); + QString issuesData; + + QUrl url("https://api.github.com/repos/" + repo + "/issues"); + QNetworkRequest request(url); + + QNetworkAccessManager manager; + QNetworkReply *reply = manager.get(request); + + request.setHeader(QNetworkRequest::UserAgentHeader, "CodeKeeper"); + request.setRawHeader("Authorization", ("Bearer " + git_token).toUtf8()); + request.setRawHeader("X-GitHub-Api-Version", "2022-11-28"); + request.setRawHeader("Accept", "application/vnd.github.v3+json"); + + QEventLoop loop; + QObject::connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit); + + loop.exec(); + + if (reply->error() == QNetworkReply::NoError) { + QByteArray data = reply->readAll(); + QJsonDocument json = QJsonDocument::fromJson(data); + QJsonArray issues = json.array(); + + qDebug() << json; + + foreach (const QJsonValue &issue, issues) { + QJsonObject issueObject = issue.toObject(); + QString title = issueObject["title"].toString(); + QString body = issueObject["body"].toString(); + QString shortBody = body.left(maxLength); + QString link = issueObject["html_url"].toString(); + + issuesData += "

" + title + "

" + shortBody + "

Open
"; + } + } else { + qWarning() << "Error: " << reply->errorString(); + } + reply->deleteLater(); + + qDebug() << issuesData; + return issuesData; +} diff --git a/src/CodeKeeper/keeperFunc/projectsFunc.cpp b/src/CodeKeeper/keeperFunc/projectsFunc.cpp index 7a5a5752..3df9a393 100644 --- a/src/CodeKeeper/keeperFunc/projectsFunc.cpp +++ b/src/CodeKeeper/keeperFunc/projectsFunc.cpp @@ -130,7 +130,7 @@ void MainWindow::openProject(QListWidget *listWidget, QListWidgetItem *item) QTabWidget *tabs = new QTabWidget(); tabs->setMovable(true); - tabs->setTabPosition(QTabWidget::South); + // tabs->setTabPosition(QTabWidget::South); QWidget *projectTab = new QWidget(); QGridLayout mainLayout(projectTab); @@ -227,10 +227,31 @@ void MainWindow::openProject(QListWidget *listWidget, QListWidgetItem *item) mainLayout.addWidget(cancelBtn, 7, 0, 1, 2, Qt::AlignCenter); mainLayout.addWidget(lastMod, 5, 0, 1, 2, Qt::AlignCenter); + QWidget *issuesTab = new QWidget(); + QGridLayout issuesLayout(issuesTab); + + QLabel *issuesLabel = new QLabel(); + issuesLabel->setWordWrap(true); + issuesLabel->setTextFormat(Qt::RichText); + issuesLabel->setTextInteractionFlags(Qt::TextBrowserInteraction); + issuesLabel->setText("Issues"); + issuesLabel->setOpenExternalLinks(true); + issuesLabel->setFont(selectedFont); + issuesLabel->setStyleSheet("font-size: " + font_size + "pt;"); + issuesLabel->setAlignment(Qt::AlignCenter); + issuesLayout.addWidget(issuesLabel, 0, 0, 1, 3); + + tabs->addTab(projectTab, "Project"); + tabs->addTab(issuesTab, "Issues"); + + centralLayout->addWidget(tabs); + QThread *thread = new QThread; - QObject::connect(thread, &QThread::started, this, [this, projectData, git_stats]() { - getRepositoryData(projectData[1], git_stats); - }); + QObject::connect(thread, &QThread::started, this, + [this, projectData, git_stats, issuesLabel]() { + getRepositoryData(projectData[1], git_stats); + issuesLabel->setText(getProjectIssues(projectData[1])); + }); thread->start(); QObject::connect(saveDataBtn, &QPushButton::clicked, [&]() { @@ -265,23 +286,14 @@ void MainWindow::openProject(QListWidget *listWidget, QListWidgetItem *item) // createGitBadges(repo, git_stats); QThread *thread = new QThread; - QObject::connect( - thread, &QThread::started, this, - [this, projectData, repo, git_stats]() { getRepositoryData(repo, git_stats); }); + QObject::connect(thread, &QThread::started, this, + [this, projectData, repo, git_stats, issuesLabel]() { + getRepositoryData(repo, git_stats); + issuesLabel->setText(getProjectIssues(repo)); + }); thread->start(); }); - - - - QWidget *issuesTab = new QWidget(); - QGridLayout issuesLayout(issuesTab); - - tabs->addTab(projectTab, "Project"); - tabs->addTab(issuesTab, "Issues"); - - centralLayout->addWidget(tabs); - dialog.exec(); } else { qWarning() << "Error"; diff --git a/src/CodeKeeper/mainwindow.h b/src/CodeKeeper/mainwindow.h index 28230d20..a9d068ec 100644 --- a/src/CodeKeeper/mainwindow.h +++ b/src/CodeKeeper/mainwindow.h @@ -150,6 +150,7 @@ class MainWindow : public QMainWindow private slots: QString getRepositoryData(QString git_url, QTableWidget *table); + QString getProjectIssues(QString git_url); void openSettingsWindow(); void fOpenAccountWindow();