Overhauled ListPage. Now it takes advantage of the Node system, and also it now has pagination support.

This commit is contained in:
Relintai 2022-02-04 15:55:19 +01:00
parent 65892ddd5a
commit 3a5487b2ab
2 changed files with 124 additions and 23 deletions

View File

@ -1,36 +1,59 @@
#include "list_page.h" #include "list_page.h"
#include "core/database/query_builder.h" #include "core/html/html_builder.h"
#include "core/database/query_result.h"
#include "core/database/table_builder.h"
#include "core/utils.h" #include "core/utils.h"
#include "core/math/math.h"
#include <tinydir/tinydir.h> #include <tinydir/tinydir.h>
#include <iostream> #include <iostream>
void ListPage::handle_request_main(Request *request) { void ListPage::handle_request_main(Request *request) {
String r = ""; if (_pages.size() == 0) {
render_menu(request);
for (uint32_t i = 0; i < list_entries.size(); ++i) { request->body += _no_entries_response;
r += "<div class=\"list_entry\">" + list_entries[i] + "</div>"; request->compile_and_send_body();
return;
} }
request->body += r; const String &cs = request->get_current_path_segment();
if (cs == "") {
render_menu(request);
request->body += _pages[0];
request->compile_and_send_body();
return;
}
if (!cs.is_uint()) {
request->send_error(HTTP_STATUS_CODE_404_NOT_FOUND);
return;
}
int p = cs.to_int();
p = ((p == 0) ? (0) : (p - 1));
if (p < 0 || p >= _pages.size()) {
request->send_error(HTTP_STATUS_CODE_404_NOT_FOUND);
return;
}
render_menu(request);
request->body += _pages[p];
request->compile_and_send_body(); request->compile_and_send_body();
} }
void ListPage::load() { void ListPage::load() {
if (folder == "") { if (folder == "") {
printf("Error: ListPage::load called, but a folder is not set!"); RLOG_ERR("Error: ListPage::load called, but a folder is not set!");
return; return;
} }
std::vector<String> files; Vector<String> files;
tinydir_dir dir; tinydir_dir dir;
if (tinydir_open(&dir, folder.c_str()) == -1) { if (tinydir_open(&dir, folder.c_str()) == -1) {
printf("Error opening ListPage::folder! folder: %s\n", folder.c_str()); RLOG_ERR("Error opening ListPage::folder! folder: \n" + folder);
return; return;
} }
@ -55,11 +78,13 @@ void ListPage::load() {
// todo // todo
// std::sort(files.begin(), files.end()); // std::sort(files.begin(), files.end());
Vector<String> list_entries;
for (uint32_t i = 0; i < files.size(); ++i) { for (uint32_t i = 0; i < files.size(); ++i) {
FILE *f = fopen(files[i].c_str(), "r"); FILE *f = fopen(files[i].c_str(), "r");
if (!f) { if (!f) {
printf("Settings::parse_file: Error opening file!\n"); RLOG_ERR("Settings::parse_file: Error opening file!\n");
return; return;
} }
@ -77,10 +102,74 @@ void ListPage::load() {
list_entries.push_back(fd); list_entries.push_back(fd);
} }
render_entries(list_entries);
render_no_entries_response();
}
void ListPage::render_entries(const Vector<String> &list_entries) {
if (list_entries.size() == 0) {
return;
}
int pages = Math::floorf_int(Math::divf(list_entries.size(), entry_per_page));
for (int i = 0; i < pages; ++i) {
String r = "";
int efrom = i * entry_per_page;
int eto = MIN((i + 1) * entry_per_page, list_entries.size());
r = render_page(i, pages, list_entries, efrom, eto);
_pages.push_back(r);
}
}
String ListPage::render_page(const int page_index, const int page_count, const Vector<String> &list_entries, const int efrom, const int eto) {
String r = "";
for (int i = efrom; i < eto; ++i) {
r += render_entry(list_entries[i]);
}
r += Utils::get_pagination(get_full_uri(), page_count, page_index, max_visible_navigation_links);
return r;
}
String ListPage::render_entry(const String &list_entry) {
HTMLBuilder b;
b.div("list_entry")->w(list_entry)->cdiv();
return b.result;
}
void ListPage::render_no_entries_response() {
HTMLBuilder b;
b.div("list_entry")->w("No conteny yet!")->cdiv();
_no_entries_response = b.result;
}
void ListPage::_notification(const int what) {
switch (what) {
case NOTIFICATION_ENTER_TREE:
load();
break;
case NOTIFICATION_EXIT_TREE:
_pages.clear();
break;
default:
break;
}
} }
ListPage::ListPage() : ListPage::ListPage() :
WebNode() { WebNode() {
max_visible_navigation_links = 6;
entry_per_page = 1;
} }
ListPage::~ListPage() { ListPage::~ListPage() {

View File

@ -8,7 +8,6 @@
#include "core/http/request.h" #include "core/http/request.h"
class ListPage : public WebNode { class ListPage : public WebNode {
RCPP_OBJECT(ListPage, WebNode); RCPP_OBJECT(ListPage, WebNode);
@ -17,11 +16,24 @@ public:
void load(); void load();
virtual void render_entries(const Vector<String> &list_entries);
virtual String render_page(const int page_index, const int page_count, const Vector<String> &list_entries, const int efrom, const int eto);
virtual String render_entry(const String &list_entry);
virtual void render_no_entries_response();
void _notification(const int what);
ListPage(); ListPage();
~ListPage(); ~ListPage();
Vector<String> list_entries; bool paginate;
int max_visible_navigation_links;
int entry_per_page;
String folder; String folder;
protected:
Vector<String> _pages;
String _no_entries_response;
}; };
#endif #endif