1
0
Fork 0
mirror of https://gitlab.com/niansa/qcommsy.git synced 2025-03-06 20:53:33 +01:00

Improved UI and fixed caching bug in libcommsy

This commit is contained in:
niansa 2020-08-27 16:23:05 +02:00
parent f692d1fd15
commit ab3649739a
3 changed files with 83 additions and 13 deletions

View file

@ -1,4 +1,4 @@
#include <iostream>
#include <iostream>
#include <string>
#include <sstream>
#include <fstream>
@ -31,6 +31,10 @@ static std::string server_url;
static std::string server_sid;
static std::string room;
namespace taskState {
enum type {none, done, inProgress, todo};
}
std::string ltrim(const std::string& s) {
static const std::regex lws{"^[[:space:]]*", std::regex_constants::extended};
@ -240,6 +244,25 @@ bool get_post_unread(GumboNode *node) {
return !elems.empty();
}
taskState::type get_post_taskState(GumboNode *node) {
// Find all elements that could contain the information we need and grab their "class" attribute
std::vector<std::string> divClassAttrs;
divClassAttrs = gumbo_get_attr(node, "class", GUMBO_TAG_I);
// Try to find the information we need
for (const auto& classAttr : divClassAttrs) {
if (classAttr.find("todo") != std::string::npos) {
return taskState::todo;
} else if (classAttr.find("inProgress") != std::string::npos) {
return taskState::inProgress;
} else if (classAttr.find("DONE(?)") != std::string::npos) { // TODO
return taskState::done;
}
}
return taskState::none;
}
std::vector<std::map<std::string, std::string>> get_post_files(GumboNode *node) {
std::vector<GumboNode *> metanodes;
std::vector<std::string> fileurls;
@ -317,16 +340,17 @@ struct commsyFile {
struct commsyPost {
std::string name;
std::string id;
std::string description;
std::string description = "\xFF";
std::string meta;
std::string url;
bool unread;
taskState::type taskState;
std::vector<commsyFile> files;
};
#define libCommsy_NAME "libcommsy"
#define libCommsy_VERSION "1.2-stable"
#define libCommsy_VERSION "1.3-stable"
class libCommsy {
public:
std::vector<commsyPost> posts;
@ -351,10 +375,11 @@ public:
commsyPost *thispost = getPost(postID);
// Check if post description was downloaded already
if (thispost->description.empty()) {
if (thispost->description == "\xFF") {
// Download post
thispost->description = get_post_desc(server_url + thispost->url);
}
// Return it
return &thispost->description;
}
@ -411,6 +436,8 @@ public:
thispost.meta = get_post_meta(*it);
// Get if post is unread
thispost.unread = get_post_unread(*it);
// Get posts task state
thispost.taskState = get_post_taskState(*it);
// Get posts URL
thispost.url = get_post_url(*it);
// Get posts files

View file

@ -21,6 +21,8 @@
#include <QFile>
#include <QTimer>
#include <QMainWindow>
#include <QListWidgetItem>
#include <QFont>
#include <QStyleFactory>
#include <QDesktopServices>
#include <QSettings>
@ -48,7 +50,7 @@ public:
void overviewWindow(bool catchInvalidRoomError = true);
void loginWindow(const QString& failure = "");
void infoWindow();
void postViewWindow(commsyPost *thispost, const QString& description);
void postViewWindow(commsyPost *thispost, QString description);
void offlineWindow();
_UILoader () {
@ -237,7 +239,7 @@ void _UILoader::loginWindow(const QString& failure) {
});
}
void _UILoader::postViewWindow(commsyPost *thispost, const QString& description) {
void _UILoader::postViewWindow(commsyPost *thispost, QString description) {
Ui::postViewWindow *thisui = new Ui::postViewWindow;
// Show initial UI
@ -245,14 +247,24 @@ void _UILoader::postViewWindow(commsyPost *thispost, const QString& description)
w->show();
thisui->statusText->setVisible(false);
// Remove trailing space from description
if (description.size() != 0 and description.back() == '\n') {
description.chop(1);
}
// Update informations
thisui->titleText->setText(QString::fromStdString(thispost->name));
thisui->metaText->setText(QString::fromStdString(thispost->meta));
thisui->descriptionText->setText(description);
// Update file list
for (const auto& thisfile : thispost->files) {
thisui->fileList->addItem(QString::fromStdString(thisfile.name));
// Update file list if required
if (thispost->files.size() != 0) {
for (const auto& thisfile : thispost->files) {
thisui->fileList->addItem(QString::fromStdString(thisfile.name));
}
} else { // If no files exist, hide the list
thisui->filesInfo->setHidden(true);
thisui->fileList->setHidden(true);
}
// Add button handlers
@ -317,18 +329,36 @@ void _UILoader::overviewWindow(bool catchInvalidRoomError) {
return failureWindow();
}
// Get font used for unread posts
QFont unreadFont = QFont();
unreadFont.setBold(true);
// Refresh view
thisui->postCounter->setText(QString::number(connector->numposts) + " Einträge");
thisui->postList->clear();
for (const auto& thispost : connector->posts) {
QString displayName;
QListWidgetItem *thisitem = new QListWidgetItem(QString::fromStdString(thispost.name), thisui->postList);
if (thispost.unread) {
displayName.append("(NEU) ");
thisitem->setFont(unreadFont);
}
displayName.append(QString::fromStdString(thispost.name));
thisui->postList->addItem(displayName);
QString postIcon;
switch(thispost.taskState) {
case taskState::done:
postIcon = "checkbox-checked-symbolic";
break;
case taskState::inProgress:
postIcon = "clock";
break;
case taskState::todo:
postIcon = "emblem-important-symbolic";
break;
default:
postIcon = "arrow-right";
break;
}
thisitem->setIcon(QIcon::fromTheme(postIcon));
}
}
}

View file

@ -80,6 +80,19 @@
</property>
</widget>
</item>
<item>
<spacer name="verticalSpacer">
<property name="orientation">
<enum>Qt::Vertical</enum>
</property>
<property name="sizeHint" stdset="0">
<size>
<width>20</width>
<height>40</height>
</size>
</property>
</spacer>
</item>
<item>
<widget class="QLabel" name="filesInfo">
<property name="text">