mirror of
https://github.com/ByteWelder/Tactility.git
synced 2026-02-22 00:15:05 +00:00
- Added `AppHub` app - Added `AppHubDetails` app - Added `cJSON` dependency - Renamed `AppSim` module to `FirmwareSim` - Added extra `tt::app::alertdialg::start()` - Renamed `addApp()`, `removeApp()`, `findAppById()` and `getApps()` to `addAppManifest()`, `removeAppManifest()`, `findAppManifestById()` and `getAppManifests()` - Added `tt::lvgl::toolbar_clear_actions()` - Added `tt::network::EspHttpClient` as a thread-safe wrapper around `esp_http_client` - Added `tt::network::http::download()` to download files - Added `tt::network::ntp::isSynced()` - When time is synced, the timestamp is stored in NVS flash. On boot, it is restored. This helps SSL connections when doing a quick reset: when WiFi reconnects, the user doesn't have to wait for NTP sync before SSL works. - Added `tt::json::Reader` as a `cJSON` wrapper - Added `int64_t` support for `Preferences` - Added `int64_t` support for `Bundle` - Added dependencies: `cJSON`, `esp-tls` - When time is synced via NTP, disable time sync. - Added docs to 'tt::file::` functions - Added `tt::string::join()` that works with `std::vector<const char*>` - Fixed `tt::file::getLastPathSegment()` for the scenario when a path was passed with only a single segment - Set `CONFIG_ESP_MAIN_TASK_STACK_SIZE=5120` (from about 3k) for all boards - Set `CONFIG_MBEDTLS_SSL_PROTO_TLS1_3=y` for all boards
61 lines
2.1 KiB
C++
61 lines
2.1 KiB
C++
#include <Tactility/app/AppRegistration.h>
|
|
#include <Tactility/service/loader/Loader.h>
|
|
#include <Tactility/lvgl/Toolbar.h>
|
|
|
|
#include <Tactility/Assets.h>
|
|
|
|
#include <lvgl.h>
|
|
#include <algorithm>
|
|
|
|
namespace tt::app::applist {
|
|
|
|
class AppListApp final : public App {
|
|
|
|
static void onAppPressed(lv_event_t* e) {
|
|
const auto* manifest = static_cast<const AppManifest*>(lv_event_get_user_data(e));
|
|
start(manifest->appId);
|
|
}
|
|
|
|
static void createAppWidget(const std::shared_ptr<AppManifest>& manifest, lv_obj_t* list) {
|
|
const void* icon = !manifest->appIcon.empty() ? manifest->appIcon.c_str() : TT_ASSETS_APP_ICON_FALLBACK;
|
|
lv_obj_t* btn = lv_list_add_button(list, icon, manifest->appName.c_str());
|
|
lv_obj_add_event_cb(btn, &onAppPressed, LV_EVENT_SHORT_CLICKED, manifest.get());
|
|
}
|
|
|
|
public:
|
|
|
|
void onShow(TT_UNUSED AppContext& app, lv_obj_t* parent) override {
|
|
auto* toolbar = lvgl::toolbar_create(parent, app);
|
|
lv_obj_align(toolbar, LV_ALIGN_TOP_MID, 0, 0);
|
|
|
|
lv_obj_t* list = lv_list_create(parent);
|
|
lv_obj_set_width(list, LV_PCT(100));
|
|
lv_obj_align_to(list, toolbar, LV_ALIGN_OUT_BOTTOM_MID, 0, 0);
|
|
|
|
auto toolbar_height = lv_obj_get_height(toolbar);
|
|
auto parent_content_height = lv_obj_get_content_height(parent);
|
|
lv_obj_set_height(list, parent_content_height - toolbar_height);
|
|
|
|
auto manifests = getAppManifests();
|
|
std::ranges::sort(manifests, SortAppManifestByName);
|
|
|
|
for (const auto& manifest: manifests) {
|
|
bool is_valid_category = (manifest->appCategory == Category::User) || (manifest->appCategory == Category::System);
|
|
bool is_visible = (manifest->appFlags & AppManifest::Flags::Hidden) == 0u;
|
|
if (is_valid_category && is_visible) {
|
|
createAppWidget(manifest, list);
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
extern const AppManifest manifest = {
|
|
.appId = "AppList",
|
|
.appName = "Apps",
|
|
.appCategory = Category::System,
|
|
.appFlags = AppManifest::Flags::Hidden,
|
|
.createApp = create<AppListApp>,
|
|
};
|
|
|
|
} // namespace
|