mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-12-22 02:33:10 +00:00
b9a766d909
* Added support for running applications from SD card (FAPs - Flipper Application Packages) * Added plugin_dist target for fbt to build FAPs * All apps of type FlipperAppType.EXTERNAL and FlipperAppType.PLUGIN are built as FAPs by default * Updated VSCode configuration for new fbt features - re-deploy stock configuration to use them * Added debugging support for FAPs with fbt debug & VSCode * Added public firmware API with automated versioning Co-authored-by: hedger <hedger@users.noreply.github.com> Co-authored-by: SG <who.just.the.doctor@gmail.com> Co-authored-by: あく <alleteam@gmail.com>
104 lines
3.2 KiB
C
104 lines
3.2 KiB
C
#include <gui/gui_i.h>
|
|
#include <gui/view.h>
|
|
#include <gui/elements.h>
|
|
#include <gui/canvas.h>
|
|
#include <furi.h>
|
|
#include <input/input.h>
|
|
#include <dolphin/dolphin.h>
|
|
|
|
#include "../desktop_i.h"
|
|
#include "desktop_view_main.h"
|
|
|
|
struct DesktopMainView {
|
|
View* view;
|
|
DesktopMainViewCallback callback;
|
|
void* context;
|
|
TimerHandle_t poweroff_timer;
|
|
};
|
|
|
|
#define DESKTOP_MAIN_VIEW_POWEROFF_TIMEOUT 5000
|
|
|
|
static void desktop_main_poweroff_timer_callback(TimerHandle_t timer) {
|
|
DesktopMainView* main_view = pvTimerGetTimerID(timer);
|
|
main_view->callback(DesktopMainEventOpenPowerOff, main_view->context);
|
|
}
|
|
|
|
void desktop_main_set_callback(
|
|
DesktopMainView* main_view,
|
|
DesktopMainViewCallback callback,
|
|
void* context) {
|
|
furi_assert(main_view);
|
|
furi_assert(callback);
|
|
main_view->callback = callback;
|
|
main_view->context = context;
|
|
}
|
|
|
|
View* desktop_main_get_view(DesktopMainView* main_view) {
|
|
furi_assert(main_view);
|
|
return main_view->view;
|
|
}
|
|
|
|
bool desktop_main_input(InputEvent* event, void* context) {
|
|
furi_assert(event);
|
|
furi_assert(context);
|
|
|
|
DesktopMainView* main_view = context;
|
|
|
|
if(event->type == InputTypeShort) {
|
|
if(event->key == InputKeyOk) {
|
|
main_view->callback(DesktopMainEventOpenMenu, main_view->context);
|
|
} else if(event->key == InputKeyUp) {
|
|
main_view->callback(DesktopMainEventOpenLockMenu, main_view->context);
|
|
} else if(event->key == InputKeyDown) {
|
|
main_view->callback(DesktopMainEventOpenArchive, main_view->context);
|
|
} else if(event->key == InputKeyLeft) {
|
|
main_view->callback(DesktopMainEventOpenFavoritePrimary, main_view->context);
|
|
} else if(event->key == InputKeyRight) {
|
|
main_view->callback(DesktopMainEventOpenPassport, main_view->context);
|
|
}
|
|
} else if(event->type == InputTypeLong) {
|
|
if(event->key == InputKeyDown) {
|
|
main_view->callback(DesktopMainEventOpenDebug, main_view->context);
|
|
} else if(event->key == InputKeyLeft) {
|
|
main_view->callback(DesktopMainEventOpenFavoriteSecondary, main_view->context);
|
|
}
|
|
}
|
|
|
|
if(event->key == InputKeyBack) {
|
|
if(event->type == InputTypePress) {
|
|
xTimerChangePeriod(
|
|
main_view->poweroff_timer,
|
|
pdMS_TO_TICKS(DESKTOP_MAIN_VIEW_POWEROFF_TIMEOUT),
|
|
portMAX_DELAY);
|
|
} else if(event->type == InputTypeRelease) {
|
|
xTimerStop(main_view->poweroff_timer, portMAX_DELAY);
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
DesktopMainView* desktop_main_alloc() {
|
|
DesktopMainView* main_view = malloc(sizeof(DesktopMainView));
|
|
|
|
main_view->view = view_alloc();
|
|
view_allocate_model(main_view->view, ViewModelTypeLockFree, 1);
|
|
view_set_context(main_view->view, main_view);
|
|
view_set_input_callback(main_view->view, desktop_main_input);
|
|
|
|
main_view->poweroff_timer = xTimerCreate(
|
|
NULL,
|
|
pdMS_TO_TICKS(DESKTOP_MAIN_VIEW_POWEROFF_TIMEOUT),
|
|
pdFALSE,
|
|
main_view,
|
|
desktop_main_poweroff_timer_callback);
|
|
|
|
return main_view;
|
|
}
|
|
|
|
void desktop_main_free(DesktopMainView* main_view) {
|
|
furi_assert(main_view);
|
|
view_free(main_view->view);
|
|
furi_timer_free(main_view->poweroff_timer);
|
|
free(main_view);
|
|
}
|