mirror of
https://github.com/meshtastic/firmware.git
synced 2026-01-12 04:47:23 +00:00
* First try at multimessage storage and display * Nrf built issue fix * Message view mode * Add channel name instead of channel slot * trunk fix * Fix for DM threading * fix for message time * rename of view mode to Conversations * Reply in thread feature * rename Select View Mode to Select Conversation * dismiss all live fix * Messages from phone show on screen * Decoupled message packets from screen.cpp and cleaned up * Cannedmessage cleanup and emotes fixed * Ack on messages sent * Ack message cleanup * Dismiss feature fixed * removed legacy temporary messages * Emote picker fix * Memory size debug * Build error fix * Sanity checks are okay sometimes * Lengthen channel name and finalize cleanup removal of Broadcast * Change DM to @ in order to unify on a single method * Continue unifying display, also show message status on the "isMine" lines * Add context for incoming messages * Better to say "in" vs "on" * crash fix for confirmation nodes * Fix outbound labels based to avoid creating delays * Eink autoscroll dissabled * gating for message storage when not using a screen * revert * Build fail fix * Don't error out with unset MAC address in unit tests * Provide some extra spacing for low hanging characters in messages * Reorder menu options and reword Respond * Reword menus to better reflect actions * Go to thread from favorite screen * Reorder Favorite Action Menu with simple word modifications * Consolidate wording on "Chats" * Mute channel fix * trunk fix * Clean up how muting works along with when we wake the screen * Fix builds for HELTEC_MESH_SOLAR * Signal bars for message ack * fix for notification renderer * Remove duplicate code, fix more Chats, and fix C6L MessageRenderer * Fix to many warnings related to BaseUI * preset aware signal strength display * More C6L fixes and clean up header lines * Use text aligns for message layout where necessary * Attempt to fix memory usage of invalidLifetime * Update channel mute for adjusted protobuf * Missed a comma in merge conflicts * cleanup to get more space * Trunk fixes * Optimize Hi Rez Chirpy to save space * more fixes * More cleanup * Remove used getConversationWith * Remove unused dismissNewestMessage * Fix another build error on occassion * Dimiss key combo function deprecated * More cleanup * Fn symbol code removed * Waypoint cleanup * Trunk fix * Fixup Waypoint screen with BaseUI code * Implement Haruki's ClockRenderer and broadcast decomposeTime across various files. * Revert "Implement Haruki's ClockRenderer and broadcast decomposeTime across various files." This reverts commit2f65721774. * Implement Haruki's ClockRenderer and broadcast decomposeTime across various files. Attempt 2! * remove memory usage debug * Revert only RangeTestModule.cpp change * Switch from dynamic std::string storage to fixed-size char[] * Removing old left over code * More optimization * Free Heap when not on Message screen * build error fixes * Restore ellipsis to end of long names * Remove legacy function renderMessageContent * improved destination filtering * force PKI * cleanup * Shorten longNames to not exceed message popups * log messages sent from apps * Trunk fix * Improve layout of messages screen * Fix potential crash for undefined variable * Revert changes to RedirectablePrint.cpp * Apply shortening to longNames in Select Destination * Fix short name displays * Fix sprintfOverlappingData issue * Fix nullPointerRedundantCheck warning on ESP32 * Add "Delete All Chats" to all chat views * Improve getSafeNodeName / sanitizeString code. * Improve getSafeNodeName further * Restore auto favorite; but only if not CLIENT_BASE * Don't favorite if WE are CLIENT_BASE role * Don't run message persistent in MUI * Fix broken endifs * Unkwnown nodes no longer show as ??? on message thread * More delete options and cleanup of code * fix for delete this chat * Message menu cleanup * trunk fix * Clean up some menu options and remove some Unit C6L ifdefines * Rework Delete flow * Desperate times call for desperate measures * Create a background on the connected icon to reduce overlap impact * Optimize code for background image * Fix for Muzi_Base * Trunk Fixes * Remove the up/down shortcut to launch canned messages (#8370) * Remove the up/down shortcut to launch canned messages * Enabled MQTT and WEBSERVER by default (#8679) Signed-off-by: kur1k0 <zhuzirun@m5stack.com> Co-authored-by: Ben Meadors <benmmeadors@gmail.com> Co-authored-by: Jonathan Bennett <jbennett@incomsystems.biz> --------- Signed-off-by: kur1k0 <zhuzirun@m5stack.com> Co-authored-by: Riker <zhuzirun@m5stack.com> Co-authored-by: Ben Meadors <benmmeadors@gmail.com> * Correct string length calculation for signal bars * Manual message scrolling * Fix * Restore CannedMessages on Home Frame * UpDown situational destination for textMessage * Correct up/down destinations on textMessage frame * Update Screen.h for handleTextMessage * Update Screen.cpp to repair a merge issue * Add nudge scroll on UpDownEncoder devices. * Set nodeName to maximum size * Revert "Set nodeName to maximum size" This reverts commite254f39925. * Reflow Node Lists and TLora Pager Views (#8942) * Add files via upload * Move files into the right place * Short or Long Names for everyone! * Add scrolling to Node list * Pagination fix for Latest to oldest per page * Page counters * Dynamic scaling of column counts based upon screen size, clean up box drawing * Reflow Node Lists and TLora Pager Views (#8942) * Add files via upload * Move files into the right place * Short or Long Names for everyone! * Add scrolling to Node list * Pagination fix for Latest to oldest per page * Page counters * Dynamic scaling of column counts based upon screen size, clean up box drawing * Update exempt labels for stale bot workflow Adds triaged and backlog to the list of exempt labels. * Update naming of Frame Visibility toggles * Fix to scrolling * Fix for content cutting off when from us * Fix for "delete this chat" now it does delete the current one * Rework isHighResolution to be an enum called ScreenResolution * Migrate Unit C6L macro guards into currentResolution UltraLow checks * Mistakes happen - restoring NodeList Renderer line --------- Signed-off-by: kur1k0 <zhuzirun@m5stack.com> Co-authored-by: Jason P <applewiz@mac.com> Co-authored-by: Jonathan Bennett <jbennett@incomsystems.biz> Co-authored-by: Riker <zhuzirun@m5stack.com> Co-authored-by: Ben Meadors <benmmeadors@gmail.com> Co-authored-by: whywilson <m.tools@qq.com> Co-authored-by: Tom Fifield <tom@tomfifield.net>
126 lines
4.2 KiB
C++
126 lines
4.2 KiB
C++
#include "SystemCommandsModule.h"
|
|
#include "input/InputBroker.h"
|
|
#include "meshUtils.h"
|
|
|
|
#if HAS_SCREEN
|
|
#include "MessageStore.h"
|
|
#include "graphics/Screen.h"
|
|
#include "graphics/SharedUIDisplay.h"
|
|
#endif
|
|
|
|
#include "GPS.h"
|
|
#include "MeshService.h"
|
|
#include "Module.h"
|
|
#include "NodeDB.h"
|
|
#include "main.h"
|
|
#include "modules/AdminModule.h"
|
|
#include "modules/ExternalNotificationModule.h"
|
|
|
|
SystemCommandsModule *systemCommandsModule;
|
|
|
|
SystemCommandsModule::SystemCommandsModule()
|
|
{
|
|
if (inputBroker)
|
|
inputObserver.observe(inputBroker);
|
|
}
|
|
|
|
int SystemCommandsModule::handleInputEvent(const InputEvent *event)
|
|
{
|
|
LOG_INPUT("SystemCommands Input event %u! kb %u", event->inputEvent, event->kbchar);
|
|
// System commands (all others fall through)
|
|
switch (event->kbchar) {
|
|
// Fn key symbols
|
|
case INPUT_BROKER_MSG_FN_SYMBOL_ON:
|
|
case INPUT_BROKER_MSG_FN_SYMBOL_OFF:
|
|
return 0;
|
|
// Brightness
|
|
case INPUT_BROKER_MSG_BRIGHTNESS_UP:
|
|
IF_SCREEN(screen->increaseBrightness());
|
|
LOG_DEBUG("Increase Screen Brightness");
|
|
return 0;
|
|
case INPUT_BROKER_MSG_BRIGHTNESS_DOWN:
|
|
IF_SCREEN(screen->decreaseBrightness());
|
|
LOG_DEBUG("Decrease Screen Brightness");
|
|
return 0;
|
|
// Mute
|
|
case INPUT_BROKER_MSG_MUTE_TOGGLE:
|
|
if (moduleConfig.external_notification.enabled && externalNotificationModule) {
|
|
bool isMuted = externalNotificationModule->getMute();
|
|
externalNotificationModule->setMute(!isMuted);
|
|
IF_SCREEN(graphics::isMuted = !isMuted; if (!isMuted) externalNotificationModule->stopNow();
|
|
screen->showSimpleBanner(isMuted ? "Notifications\nEnabled" : "Notifications\nDisabled", 3000);)
|
|
}
|
|
return 0;
|
|
// Bluetooth
|
|
case INPUT_BROKER_MSG_BLUETOOTH_TOGGLE:
|
|
config.bluetooth.enabled = !config.bluetooth.enabled;
|
|
LOG_INFO("User toggled Bluetooth");
|
|
nodeDB->saveToDisk();
|
|
#if defined(ARDUINO_ARCH_NRF52)
|
|
if (!config.bluetooth.enabled) {
|
|
disableBluetooth();
|
|
IF_SCREEN(screen->showSimpleBanner("Bluetooth OFF\nRebooting", 3000));
|
|
rebootAtMsec = millis() + DEFAULT_REBOOT_SECONDS * 2000;
|
|
} else {
|
|
IF_SCREEN(screen->showSimpleBanner("Bluetooth ON\nRebooting", 3000));
|
|
rebootAtMsec = millis() + DEFAULT_REBOOT_SECONDS * 1000;
|
|
}
|
|
#else
|
|
if (!config.bluetooth.enabled) {
|
|
disableBluetooth();
|
|
IF_SCREEN(screen->showSimpleBanner("Bluetooth OFF", 3000));
|
|
} else {
|
|
IF_SCREEN(screen->showSimpleBanner("Bluetooth ON\nRebooting", 3000));
|
|
rebootAtMsec = millis() + DEFAULT_REBOOT_SECONDS * 1000;
|
|
}
|
|
#endif
|
|
return 0;
|
|
case INPUT_BROKER_MSG_REBOOT:
|
|
IF_SCREEN(screen->showSimpleBanner("Rebooting...", 0));
|
|
nodeDB->saveToDisk();
|
|
#if HAS_SCREEN
|
|
messageStore.saveToFlash();
|
|
#endif
|
|
rebootAtMsec = millis() + DEFAULT_REBOOT_SECONDS * 1000;
|
|
// runState = CANNED_MESSAGE_RUN_STATE_INACTIVE;
|
|
return true;
|
|
}
|
|
|
|
switch (event->inputEvent) {
|
|
// GPS
|
|
case INPUT_BROKER_GPS_TOGGLE:
|
|
#if !MESHTASTIC_EXCLUDE_GPS
|
|
if (gps) {
|
|
if (config.position.gps_mode == meshtastic_Config_PositionConfig_GpsMode_ENABLED &&
|
|
config.position.fixed_position == false) {
|
|
nodeDB->clearLocalPosition();
|
|
nodeDB->saveToDisk();
|
|
}
|
|
gps->toggleGpsMode();
|
|
const char *msg =
|
|
(config.position.gps_mode == meshtastic_Config_PositionConfig_GpsMode_ENABLED) ? "GPS Enabled" : "GPS Disabled";
|
|
IF_SCREEN(screen->forceDisplay(); screen->showSimpleBanner(msg, 3000);)
|
|
}
|
|
#endif
|
|
return true;
|
|
// Mesh ping
|
|
case INPUT_BROKER_SEND_PING:
|
|
service->refreshLocalMeshNode();
|
|
if (service->trySendPosition(NODENUM_BROADCAST, true)) {
|
|
IF_SCREEN(screen->showSimpleBanner("Position\nSent", 3000));
|
|
} else {
|
|
IF_SCREEN(screen->showSimpleBanner("Node Info\nSent", 3000));
|
|
}
|
|
return true;
|
|
// Power control
|
|
case INPUT_BROKER_SHUTDOWN:
|
|
shutdownAtMsec = millis();
|
|
return true;
|
|
|
|
default:
|
|
// No other input events handled here
|
|
break;
|
|
}
|
|
return false;
|
|
}
|