mirror of
https://github.com/DarkStore-3DS/DarkStore.git
synced 2026-07-03 00:39:02 +00:00
Implement Universal-Store [UniStore] 3DS side. (#13)
* WIP App store. ;P * Make the FileBrowse look like Scripts Screen. * Add *all* Script Functions for the App Store. * WIP; Store Selection & Store Screen. To-Do: Big cleanup and remove of duplicate stuff. * Some UniStore work. * :bigBruh:. * Add Spritesheet with Icon support. * Add a Store Prepare message, just in case it takes longer. * ~~Not really Camera stuff, just UniStore work.~~ (#12) * We don't want Nightly builds here. * Add UniStore Icon. * New banner by https://github.com/TotallyNotGuy * Add Buttons for a prompt & update icon. * Update README.md to be more descriptive and stuff * Update README.md * Add updating the spritesheet too. * Only update stores, if needed things exist! * Make Storepath changeable. * Change App Description. * Display `Title` as well. * You can now download .unistore files by entering a URL! Co-authored-by: FlameKat53 <flame9804@yahoo.com> * This should fix all warnings. Also add posX and posY for the Icons in UniStore. * Last changes for UniStore. Co-authored-by: FlameKat53 <flame9804@yahoo.com>
This commit is contained in:
@@ -83,7 +83,7 @@ GRAPHICS := assets/gfx
|
|||||||
ROMFS := romfs
|
ROMFS := romfs
|
||||||
GFXBUILD := $(ROMFS)/gfx
|
GFXBUILD := $(ROMFS)/gfx
|
||||||
APP_AUTHOR := Universal-Team
|
APP_AUTHOR := Universal-Team
|
||||||
APP_DESCRIPTION := A universally good updater!
|
APP_DESCRIPTION := A multiapp, JSON script-based updater for Nintendo 3DS
|
||||||
ICON := app/icon.png
|
ICON := app/icon.png
|
||||||
BNR_IMAGE := app/banner.png
|
BNR_IMAGE := app/banner.png
|
||||||
BNR_AUDIO := app/BannerAudio.wav
|
BNR_AUDIO := app/BannerAudio.wav
|
||||||
|
|||||||
@@ -1,2 +1,35 @@
|
|||||||
# Universal-Updater
|
<p align="center">
|
||||||
A universally good updater! :)
|
<img src="https://github.com/Universal-Team/Universal-Updater/blob/master/app/banner.png"><br>
|
||||||
|
<b>A multiapp, JSON script-based updater for Nintendo 3DS</b>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p align="center">
|
||||||
|
<a href="https://dev.azure.com/universal-team/Builds/_build?definitionId=13" style="padding-right: 5px;">
|
||||||
|
<img src="https://dev.azure.com/Universal-Team/Builds/_apis/build/status/Universal-Team.Universal-Updater%20(1)?branchName=master" height="20">
|
||||||
|
</a>
|
||||||
|
<a href="https://discord.gg/KDJCfGF" style="padding-left: 5px; padding-right: 5px;">
|
||||||
|
<img src="https://img.shields.io/badge/Discord-Server-blue.svg" height="20">
|
||||||
|
</a>
|
||||||
|
<a href="https://gbatemp.net/threads/release-universal-updater-a-universally-good-updater.551824/" style="padding-left: 5px;">
|
||||||
|
<img src="https://img.shields.io/badge/GBATemp-thread-blue.svg" height="20">
|
||||||
|
</a>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
## Features
|
||||||
|
|
||||||
|
Universal-Updater is packed with features! Some include the JSON script updater, an App store, an FTP server, and more!
|
||||||
|
|
||||||
|
- JSON-based Script updater
|
||||||
|
- JSON Script Downloader
|
||||||
|
- An App Store, the UniStore
|
||||||
|
- A Settings page, for configuring Universal-Updater Settings
|
||||||
|
- An FTP Server
|
||||||
|
|
||||||
|
|
||||||
|
## Compilation
|
||||||
|
|
||||||
|
To build Universal-Updater from source, you need devkitPro installed, along with devkitARM, libctru, 3ds-curl, and 3ds-libarchive. To get these you can run `pacman -S 3ds-dev --noconfirm`, then `pacman -S 3ds-curl --noconfirm`, and lastly `pacman -S 3ds-libarchive --noconfirm`. Now that you have everything installed, you just need to run clone the repository and run `make`
|
||||||
|
|
||||||
|
## Screenshots
|
||||||
|
|
||||||
|

|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
|
Before Width: | Height: | Size: 32 KiB After Width: | Height: | Size: 24 KiB |
Binary file not shown.
@@ -8,6 +8,9 @@ sprites/top_screen_bot.png
|
|||||||
sprites/top_screen_top.png
|
sprites/top_screen_top.png
|
||||||
sprites/search.png
|
sprites/search.png
|
||||||
sprites/side_arrow.png
|
sprites/side_arrow.png
|
||||||
|
sprites/uniStore.png
|
||||||
|
sprites/uniStore_HD.png
|
||||||
|
sprites/update.png
|
||||||
sprites/view.png
|
sprites/view.png
|
||||||
|
|
||||||
sprites/credits/discord.png
|
sprites/credits/discord.png
|
||||||
|
|||||||
Binary file not shown.
|
After Width: | Height: | Size: 13 KiB |
Binary file not shown.
|
After Width: | Height: | Size: 32 KiB |
Binary file not shown.
|
After Width: | Height: | Size: 1.3 KiB |
+1
-1
@@ -1,7 +1,7 @@
|
|||||||
trigger:
|
trigger:
|
||||||
branches:
|
branches:
|
||||||
include: ['*']
|
include: ['*']
|
||||||
exclude: [translation, script-creator-experimental]
|
exclude: [translation, App-Store, Camera]
|
||||||
tags:
|
tags:
|
||||||
include: ['*']
|
include: ['*']
|
||||||
|
|
||||||
|
|||||||
@@ -41,8 +41,9 @@ public:
|
|||||||
void Logic(u32 hDown, u32 hHeld, touchPosition touch) override;
|
void Logic(u32 hDown, u32 hHeld, touchPosition touch) override;
|
||||||
private:
|
private:
|
||||||
bool returnScriptState();
|
bool returnScriptState();
|
||||||
|
bool returnStoreState();
|
||||||
int Selection = 0;
|
int Selection = 0;
|
||||||
std::vector<DirEntry> dirContents; // To return Script state.
|
std::vector<DirEntry> dirContents; // To return Script/Store state.
|
||||||
std::vector<Structs::ButtonPos> mainButtons = {
|
std::vector<Structs::ButtonPos> mainButtons = {
|
||||||
{10, 40, 140, 35, -1}, // Scriptlist.
|
{10, 40, 140, 35, -1}, // Scriptlist.
|
||||||
{170, 40, 140, 35, -1}, // ScriptBrowse.
|
{170, 40, 140, 35, -1}, // ScriptBrowse.
|
||||||
|
|||||||
@@ -24,34 +24,60 @@
|
|||||||
* reasonable ways as different from the original version.
|
* reasonable ways as different from the original version.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef TINYDB_HPP
|
#ifndef UNISTORE_HPP
|
||||||
#define TINYDB_HPP
|
#define UNISTORE_HPP
|
||||||
|
|
||||||
#include "screens/screen.hpp"
|
#include "screens/screen.hpp"
|
||||||
#include "screens/screenCommon.hpp"
|
#include "screens/screenCommon.hpp"
|
||||||
|
|
||||||
|
#include "utils/fileBrowse.h"
|
||||||
#include "utils/structs.hpp"
|
#include "utils/structs.hpp"
|
||||||
|
|
||||||
class TinyDB : public screen
|
class UniStore : public screen
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
void Draw(void) const override;
|
void Draw(void) const override;
|
||||||
void Logic(u32 hDown, u32 hHeld, touchPosition touch) override;
|
void Logic(u32 hDown, u32 hHeld, touchPosition touch) override;
|
||||||
TinyDB();
|
UniStore();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void DrawStoreList(void) const;
|
||||||
|
void DrawStore(void) const;
|
||||||
|
void DrawSearch(void) const;
|
||||||
|
|
||||||
|
void StoreSelectionLogic(u32 hDown, u32 hHeld, touchPosition touch);
|
||||||
|
void StoreLogic(u32 hDown, u32 hHeld, touchPosition touch);
|
||||||
|
void SearchLogic(u32 hDown, u32 hHeld, touchPosition touch);
|
||||||
void execute();
|
void execute();
|
||||||
|
void descript();
|
||||||
|
int mode = 0;
|
||||||
|
std::string selectedOptionAppStore;
|
||||||
|
|
||||||
mutable int selection = 0;
|
mutable int selection = 0;
|
||||||
|
mutable int selection2 = 0;
|
||||||
int screenPos = 0;
|
int screenPos = 0;
|
||||||
|
int screenPos2 = 0;
|
||||||
mutable int screenPosList = 0;
|
mutable int screenPosList = 0;
|
||||||
|
mutable int screenPosList2 = 0;
|
||||||
|
|
||||||
|
int searchSelection = 0;
|
||||||
|
|
||||||
int keyRepeatDelay = 0;
|
int keyRepeatDelay = 0;
|
||||||
int fastMode = false;
|
int fastMode = false;
|
||||||
|
std::vector<DirEntry> dirContents;
|
||||||
|
|
||||||
std::vector<Structs::ButtonPos> arrowPos = {
|
std::vector<Structs::ButtonPos> arrowPos = {
|
||||||
{295, 0, 25, 25, -1}, // Arrow Up.
|
{295, 0, 25, 25, -1}, // Arrow Up.
|
||||||
{295, 215, 25, 25, -1}, // Arrow Down.
|
{295, 215, 25, 25, -1}, // Arrow Down.
|
||||||
{0, 215, 25, 25, -1}, // Back Arrow.
|
{0, 215, 25, 25, -1}, // Back Arrow.
|
||||||
{5, 0, 25, 25, -1}, // ViewMode Change.
|
{5, 0, 25, 25, -1}, // ViewMode Change.
|
||||||
{45, 0, 25, 25, -1}, // Search.
|
{45, 0, 25, 25, -1}, // Search.
|
||||||
|
{85, 0, 25, 25, -1}, // Update.
|
||||||
|
};
|
||||||
|
|
||||||
|
std::vector<Structs::ButtonPos> URLBtn = {
|
||||||
|
{10, 100, 140, 35, -1}, // FULL URL.
|
||||||
|
{170, 100, 140, 35, -1}, // Github.
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -61,4 +61,7 @@ extern char * arg0;
|
|||||||
#define WORKING_DIR "/"
|
#define WORKING_DIR "/"
|
||||||
#define SCRIPTS_PATH "sdmc:/3ds/Universal-Updater/scripts/" // The Scripts will be here.
|
#define SCRIPTS_PATH "sdmc:/3ds/Universal-Updater/scripts/" // The Scripts will be here.
|
||||||
#define MUSIC_PATH "sdmc:/3ds/Universal-Updater/Music.wav" // Default Music File / Path.
|
#define MUSIC_PATH "sdmc:/3ds/Universal-Updater/Music.wav" // Default Music File / Path.
|
||||||
#define SCRIPT_VERSION 3
|
#define SCRIPT_VERSION 3
|
||||||
|
#define STORE_PATH "sdmc:/3ds/Universal-Updater/stores/" // Default Store path.
|
||||||
|
#define ENTRIES_PER_SCREEN 3
|
||||||
|
#define ENTRIES_PER_LIST 7
|
||||||
@@ -31,7 +31,7 @@
|
|||||||
|
|
||||||
namespace Config {
|
namespace Config {
|
||||||
extern int lang, Color1, Color2, Color3, TxtColor, SelectedColor, UnselectedColor, viewMode, ColorKeys, progressbarColor;
|
extern int lang, Color1, Color2, Color3, TxtColor, SelectedColor, UnselectedColor, viewMode, ColorKeys, progressbarColor;
|
||||||
extern std::string ScriptPath, MusicPath;
|
extern std::string ScriptPath, MusicPath, StorePath;
|
||||||
extern bool Logging, UseBars;
|
extern bool Logging, UseBars;
|
||||||
|
|
||||||
void load();
|
void load();
|
||||||
|
|||||||
@@ -44,7 +44,7 @@ namespace ScriptHelper {
|
|||||||
Result createFile(const char * path);
|
Result createFile(const char * path);
|
||||||
void displayTimeMsg(std::string message, int seconds);
|
void displayTimeMsg(std::string message, int seconds);
|
||||||
|
|
||||||
bool checkIfValid(std::string scriptFile);
|
bool checkIfValid(std::string scriptFile, int mode = 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
+20
-2
@@ -86,8 +86,26 @@
|
|||||||
"FILEBROWSE_MSG": "Press X to select, Select to refresh.",
|
"FILEBROWSE_MSG": "Press X to select, Select to refresh.",
|
||||||
"SELECT_SCRIPT_PATH": "Select the Script Path.",
|
"SELECT_SCRIPT_PATH": "Select the Script Path.",
|
||||||
|
|
||||||
"CHANGE_BARS": "Change Bars",
|
"USE_BARS": "Use Bars:",
|
||||||
"CHANGE_SCRIPTPATH": "Change Scriptpath",
|
"CHANGE_SCRIPTPATH": "Change Scriptpath",
|
||||||
"CHANGE_MUSICFILE": "Change Musicfile",
|
"CHANGE_MUSICFILE": "Change Musicfile",
|
||||||
"SELECT_MUSIC_FILE": "Select the Musicfile."
|
"SELECT_MUSIC_FILE": "Select the Musicfile.",
|
||||||
|
|
||||||
|
"PULLING_APPSTORE": "Pulling App Store data...",
|
||||||
|
"VERSION": "Version: ",
|
||||||
|
"UPDATING": "Updating...",
|
||||||
|
"WOULD_YOU_LIKE_UPDATE": "Would you like to update this store?",
|
||||||
|
"GET_STORES_FIRST": "Get some Stores first!",
|
||||||
|
"PREPARE_STORE": "Prepare store... please wait.",
|
||||||
|
"YES": "Yes",
|
||||||
|
"NO": "No",
|
||||||
|
"CHANGE_STOREPATH": "Change Storepath",
|
||||||
|
"SELECT_STORE_PATH": "Select the Store Path.",
|
||||||
|
"UNKNOWN": "Unknown",
|
||||||
|
"ENTER_OWNER_AND_REPO": "Enter Owner and Repo.",
|
||||||
|
"ENTER_FILENAME": "Enter filename.",
|
||||||
|
"UNISTORE_SEARCH": "UniStore search",
|
||||||
|
"FULL_URL": "Full URL",
|
||||||
|
"GITHUB": "Github",
|
||||||
|
"ENTER_FULL_URL": "Enter the full URL."
|
||||||
}
|
}
|
||||||
|
|||||||
+24
-2
@@ -29,6 +29,7 @@
|
|||||||
#include "screens/screenCommon.hpp"
|
#include "screens/screenCommon.hpp"
|
||||||
|
|
||||||
#include "utils/config.hpp"
|
#include "utils/config.hpp"
|
||||||
|
#include "utils/structs.hpp"
|
||||||
|
|
||||||
C3D_RenderTarget* top;
|
C3D_RenderTarget* top;
|
||||||
C3D_RenderTarget* bottom;
|
C3D_RenderTarget* bottom;
|
||||||
@@ -247,6 +248,14 @@ void Gui::DrawBottom(void) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::vector<Structs::ButtonPos> promptBtn = {
|
||||||
|
{10, 100, 140, 35, -1}, // Yes.
|
||||||
|
{170, 100, 140, 35, -1}, // No.
|
||||||
|
};
|
||||||
|
|
||||||
|
extern touchPosition touch;
|
||||||
|
extern bool touching(touchPosition touch, Structs::ButtonPos button);
|
||||||
|
|
||||||
// Display a Message, which needs to be confirmed with A/B.
|
// Display a Message, which needs to be confirmed with A/B.
|
||||||
bool Gui::promptMsg(std::string promptMsg)
|
bool Gui::promptMsg(std::string promptMsg)
|
||||||
{
|
{
|
||||||
@@ -263,14 +272,27 @@ bool Gui::promptMsg(std::string promptMsg)
|
|||||||
Gui::DrawString((400-Gui::GetStringWidth(0.72f, Lang::get("CONFIRM_OR_CANCEL")))/2, 217, 0.72f, TextColor, Lang::get("CONFIRM_OR_CANCEL"), 400);
|
Gui::DrawString((400-Gui::GetStringWidth(0.72f, Lang::get("CONFIRM_OR_CANCEL")))/2, 217, 0.72f, TextColor, Lang::get("CONFIRM_OR_CANCEL"), 400);
|
||||||
}
|
}
|
||||||
Gui::DrawBottom();
|
Gui::DrawBottom();
|
||||||
|
if (isScriptSelected == false) {
|
||||||
|
Gui::Draw_Rect(10, 100, 140, 35, Config::Color1);
|
||||||
|
Gui::Draw_Rect(170, 100, 140, 35, Config::Color1);
|
||||||
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("YES")))/2-150+70, 110, 0.6f, Config::TxtColor, Lang::get("YES"), 140);
|
||||||
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("NO")))/2+150-70, 110, 0.6f, Config::TxtColor, Lang::get("NO"), 140);
|
||||||
|
} else if (isScriptSelected == true) {
|
||||||
|
Gui::Draw_Rect(10, 100, 140, 35, barColor);
|
||||||
|
Gui::Draw_Rect(170, 100, 140, 35, barColor);
|
||||||
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("YES")))/2-150+70, 110, 0.6f, TextColor, Lang::get("YES"), 140);
|
||||||
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("NO")))/2+150-70, 110, 0.6f, TextColor, Lang::get("NO"), 140);
|
||||||
|
}
|
||||||
|
|
||||||
C3D_FrameEnd(0);
|
C3D_FrameEnd(0);
|
||||||
while(1)
|
while(1)
|
||||||
{
|
{
|
||||||
gspWaitForVBlank();
|
gspWaitForVBlank();
|
||||||
hidScanInput();
|
hidScanInput();
|
||||||
if(hidKeysDown() & KEY_A) {
|
hidTouchRead(&touch);
|
||||||
|
if ((hidKeysDown() & KEY_A) || (hidKeysDown() & KEY_TOUCH && touching(touch, promptBtn[0]))) {
|
||||||
return true;
|
return true;
|
||||||
} else if(hidKeysDown() & KEY_B) {
|
} else if ((hidKeysDown() & KEY_B) || (hidKeysDown() & KEY_TOUCH && touching(touch, promptBtn[1]))) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
+1
-1
@@ -205,7 +205,7 @@ std::string Input::getString(uint maxLength, std::string Text) {
|
|||||||
Gui::DrawBottom();
|
Gui::DrawBottom();
|
||||||
drawKeyboard();
|
drawKeyboard();
|
||||||
C2D_DrawRectSolid(0, 81, 0.5f, 320, 20, Config::ColorKeys & C2D_Color32(200, 200, 200, 200));
|
C2D_DrawRectSolid(0, 81, 0.5f, 320, 20, Config::ColorKeys & C2D_Color32(200, 200, 200, 200));
|
||||||
Gui::DrawString(5, 82, 0.6, Config::TxtColor, (string+(cursorBlink-- > 0 ? "_" : "")).c_str());
|
Gui::DrawString(2, 82, 0.6, Config::TxtColor, (string+(cursorBlink-- > 0 ? "_" : "")).c_str());
|
||||||
if(cursorBlink < -20) cursorBlink = 20;
|
if(cursorBlink < -20) cursorBlink = 20;
|
||||||
scanKeys();
|
scanKeys();
|
||||||
hDown = keysDown();
|
hDown = keysDown();
|
||||||
|
|||||||
@@ -88,6 +88,7 @@ int main()
|
|||||||
mkdir("sdmc:/3ds", 0777);
|
mkdir("sdmc:/3ds", 0777);
|
||||||
mkdir("sdmc:/3ds/Universal-Updater", 0777);
|
mkdir("sdmc:/3ds/Universal-Updater", 0777);
|
||||||
mkdir("sdmc:/3ds/Universal-Updater/scripts", 0777);
|
mkdir("sdmc:/3ds/Universal-Updater/scripts", 0777);
|
||||||
|
mkdir("sdmc:/3ds/Universal-Updater/stores", 0777);
|
||||||
|
|
||||||
// We need to make sure, the file exist.
|
// We need to make sure, the file exist.
|
||||||
if(access("sdmc:/3ds/Universal-Updater/Settings.json", F_OK) == -1 ) {
|
if(access("sdmc:/3ds/Universal-Updater/Settings.json", F_OK) == -1 ) {
|
||||||
|
|||||||
@@ -88,9 +88,7 @@ void FTPScreen::Draw(void) const
|
|||||||
hidTouchRead(&touch);
|
hidTouchRead(&touch);
|
||||||
u32 hDown = hidKeysDown();
|
u32 hDown = hidKeysDown();
|
||||||
|
|
||||||
if (hDown & KEY_B)
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[0])))
|
||||||
break;
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[0]))
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
memset(ftp_accepted_connection, 0, 20); // Empty accepted connection address.
|
memset(ftp_accepted_connection, 0, 20); // Empty accepted connection address.
|
||||||
|
|||||||
@@ -32,7 +32,7 @@
|
|||||||
#include "screens/scriptCreator.hpp"
|
#include "screens/scriptCreator.hpp"
|
||||||
#include "screens/scriptlist.hpp"
|
#include "screens/scriptlist.hpp"
|
||||||
#include "screens/settings.hpp"
|
#include "screens/settings.hpp"
|
||||||
#include "screens/tinyDB.hpp"
|
#include "screens/unistore.hpp"
|
||||||
|
|
||||||
#include "utils/config.hpp"
|
#include "utils/config.hpp"
|
||||||
|
|
||||||
@@ -71,9 +71,11 @@ void MainMenu::Draw(void) const {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Draw UniStore Icon. ;P
|
||||||
|
Gui::sprite(sprites_uniStore_idx, 15, 95);
|
||||||
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("SCRIPTLIST")))/2-150+70, mainButtons[0].y+10, 0.6f, Config::TxtColor, Lang::get("SCRIPTLIST"), 140);
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("SCRIPTLIST")))/2-150+70, mainButtons[0].y+10, 0.6f, Config::TxtColor, Lang::get("SCRIPTLIST"), 140);
|
||||||
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("GET_SCRIPTS")))/2+150-70, mainButtons[1].y+10, 0.6f, Config::TxtColor, Lang::get("GET_SCRIPTS"), 140);
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("GET_SCRIPTS")))/2+150-70, mainButtons[1].y+10, 0.6f, Config::TxtColor, Lang::get("GET_SCRIPTS"), 140);
|
||||||
Gui::DrawString((320-Gui::GetStringWidth(0.6f, "TinyDB"))/2-150+70, mainButtons[2].y+10, 0.6f, Config::TxtColor, "TinyDB", 140);
|
Gui::DrawString(80, mainButtons[2].y+10, 0.6f, Config::TxtColor, "UniStore", 140);
|
||||||
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("SCRIPTCREATOR")))/2+150-70, mainButtons[3].y+10, 0.6f, Config::TxtColor, Lang::get("SCRIPTCREATOR"), 140);
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("SCRIPTCREATOR")))/2+150-70, mainButtons[3].y+10, 0.6f, Config::TxtColor, Lang::get("SCRIPTCREATOR"), 140);
|
||||||
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("SETTINGS")))/2-150+70, mainButtons[4].y+10, 0.6f, Config::TxtColor, Lang::get("SETTINGS"), 140);
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("SETTINGS")))/2-150+70, mainButtons[4].y+10, 0.6f, Config::TxtColor, Lang::get("SETTINGS"), 140);
|
||||||
Gui::DrawString((320-Gui::GetStringWidth(0.6f, "FTP"))/2+150-70, mainButtons[5].y+10, 0.6f, Config::TxtColor, "FTP", 140);
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, "FTP"))/2+150-70, mainButtons[5].y+10, 0.6f, Config::TxtColor, "FTP", 140);
|
||||||
@@ -95,6 +97,21 @@ bool MainMenu::returnScriptState() {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool MainMenu::returnStoreState() {
|
||||||
|
dirContents.clear();
|
||||||
|
chdir(Config::StorePath.c_str());
|
||||||
|
std::vector<DirEntry> dirContentsTemp;
|
||||||
|
getDirectoryContents(dirContentsTemp, {"unistore"});
|
||||||
|
for(uint i=0;i<dirContentsTemp.size();i++) {
|
||||||
|
dirContents.push_back(dirContentsTemp[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dirContents.size() == 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
void MainMenu::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
void MainMenu::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
||||||
if (hDown & KEY_START) {
|
if (hDown & KEY_START) {
|
||||||
exiting = true;
|
exiting = true;
|
||||||
@@ -129,10 +146,10 @@ void MainMenu::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
if (checkWifiStatus() == true) {
|
if (returnStoreState() == true) {
|
||||||
Screen::set(std::make_unique<TinyDB>());
|
Screen::set(std::make_unique<UniStore>());
|
||||||
} else {
|
} else {
|
||||||
notConnectedMsg();
|
Gui::DisplayWarnMsg(Lang::get("GET_STORES_FIRST"));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
@@ -161,6 +178,7 @@ void MainMenu::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH) {
|
if (hDown & KEY_TOUCH) {
|
||||||
if (touching(touch, mainButtons[0])) {
|
if (touching(touch, mainButtons[0])) {
|
||||||
if (returnScriptState() == true) {
|
if (returnScriptState() == true) {
|
||||||
@@ -175,10 +193,10 @@ void MainMenu::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
notConnectedMsg();
|
notConnectedMsg();
|
||||||
}
|
}
|
||||||
} else if (touching(touch, mainButtons[2])) {
|
} else if (touching(touch, mainButtons[2])) {
|
||||||
if (checkWifiStatus() == true) {
|
if (returnStoreState() == true) {
|
||||||
Screen::set(std::make_unique<TinyDB>());
|
Screen::set(std::make_unique<UniStore>());
|
||||||
} else {
|
} else {
|
||||||
notConnectedMsg();
|
Gui::DisplayWarnMsg(Lang::get("GET_STORES_FIRST"));
|
||||||
}
|
}
|
||||||
} else if (touching(touch, mainButtons[3])) {
|
} else if (touching(touch, mainButtons[3])) {
|
||||||
if (isTesting == true) {
|
if (isTesting == true) {
|
||||||
|
|||||||
@@ -34,8 +34,6 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
extern bool touching(touchPosition touch, Structs::ButtonPos button);
|
extern bool touching(touchPosition touch, Structs::ButtonPos button);
|
||||||
#define ENTRIES_PER_SCREEN 3
|
|
||||||
#define ENTRIES_PER_LIST 7
|
|
||||||
|
|
||||||
nlohmann::json infoJson;
|
nlohmann::json infoJson;
|
||||||
|
|
||||||
@@ -178,35 +176,13 @@ void ScriptBrowse::Draw(void) const {
|
|||||||
|
|
||||||
void ScriptBrowse::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
void ScriptBrowse::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
||||||
if (keyRepeatDelay) keyRepeatDelay--;
|
if (keyRepeatDelay) keyRepeatDelay--;
|
||||||
if (hDown & KEY_B) {
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
infoJson.clear();
|
infoJson.clear();
|
||||||
Screen::back();
|
Screen::back();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[0])) {
|
if ((hHeld & KEY_DOWN && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[1]))) {
|
||||||
if (selection > 0) {
|
|
||||||
selection--;
|
|
||||||
} else {
|
|
||||||
selection = (int)infoJson.size()-1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[1])) {
|
|
||||||
if (selection < (int)infoJson.size()-1) {
|
|
||||||
selection++;
|
|
||||||
} else {
|
|
||||||
selection = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[2])) {
|
|
||||||
infoJson.clear();
|
|
||||||
Screen::back();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hHeld & KEY_DOWN && !keyRepeatDelay) {
|
|
||||||
if (selection < (int)infoJson.size()-1) {
|
if (selection < (int)infoJson.size()-1) {
|
||||||
selection++;
|
selection++;
|
||||||
} else {
|
} else {
|
||||||
@@ -219,7 +195,7 @@ void ScriptBrowse::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hHeld & KEY_UP && !keyRepeatDelay) {
|
if ((hHeld & KEY_UP && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[0]))) {
|
||||||
if (selection > 0) {
|
if (selection > 0) {
|
||||||
selection--;
|
selection--;
|
||||||
} else {
|
} else {
|
||||||
@@ -295,7 +271,7 @@ void ScriptBrowse::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
fastMode = false;
|
fastMode = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_X || hDown & KEY_TOUCH && touching(touch, arrowPos[4])) {
|
if ((hDown & KEY_X) || (hDown & KEY_TOUCH && touching(touch, arrowPos[4]))) {
|
||||||
if (Config::viewMode == 0) {
|
if (Config::viewMode == 0) {
|
||||||
Config::viewMode = 1;
|
Config::viewMode = 1;
|
||||||
} else {
|
} else {
|
||||||
@@ -317,26 +293,7 @@ void ScriptBrowse::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_Y) {
|
if ((hDown & KEY_Y) || (hDown & KEY_TOUCH && touching(touch, arrowPos[3]))) {
|
||||||
if (infoJson.size() != 0) {
|
|
||||||
for (int i = 0; i < (int)infoJson.size(); i++) {
|
|
||||||
int current = i+1;
|
|
||||||
int total = infoJson.size();
|
|
||||||
std::string fileName = Lang::get("DOWNLOADING") + std::string(infoJson[i]["title"]);
|
|
||||||
std::string titleFix = infoJson[i]["title"];
|
|
||||||
for (int l = 0; l < (int)titleFix.size(); l++) {
|
|
||||||
if (titleFix[l] == '/') {
|
|
||||||
titleFix[l] = '-';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
DisplayMsg(fileName + " " + std::to_string(current) + " / " + std::to_string(total));
|
|
||||||
downloadToFile(infoJson[i]["url"], Config::ScriptPath + titleFix + ".json");
|
|
||||||
infoJson[i]["curRevision"] = infoJson[i]["revision"];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[3])) {
|
|
||||||
if (infoJson.size() != 0) {
|
if (infoJson.size() != 0) {
|
||||||
for (int i = 0; i < (int)infoJson.size(); i++) {
|
for (int i = 0; i < (int)infoJson.size(); i++) {
|
||||||
int current = i+1;
|
int current = i+1;
|
||||||
|
|||||||
@@ -37,8 +37,6 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
extern bool touching(touchPosition touch, Structs::ButtonPos button);
|
extern bool touching(touchPosition touch, Structs::ButtonPos button);
|
||||||
#define ENTRIES_PER_SCREEN 3
|
|
||||||
#define ENTRIES_PER_LIST 7
|
|
||||||
|
|
||||||
bool isScriptSelected = false;
|
bool isScriptSelected = false;
|
||||||
|
|
||||||
@@ -384,32 +382,36 @@ void ScriptList::DrawSingleObject(void) const {
|
|||||||
void ScriptList::ListSelection(u32 hDown, u32 hHeld, touchPosition touch) {
|
void ScriptList::ListSelection(u32 hDown, u32 hHeld, touchPosition touch) {
|
||||||
if (keyRepeatDelay) keyRepeatDelay--;
|
if (keyRepeatDelay) keyRepeatDelay--;
|
||||||
|
|
||||||
if (hDown & KEY_B) {
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
fileInfo.clear();
|
fileInfo.clear();
|
||||||
Screen::back();
|
Screen::back();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[0])) {
|
if ((hHeld & KEY_DOWN && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[1]))) {
|
||||||
if (selection > 0) {
|
|
||||||
selection--;
|
|
||||||
} else {
|
|
||||||
selection = (int)fileInfo.size()-1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[1])) {
|
|
||||||
if (selection < (int)fileInfo.size()-1) {
|
if (selection < (int)fileInfo.size()-1) {
|
||||||
selection++;
|
selection++;
|
||||||
} else {
|
} else {
|
||||||
selection = 0;
|
selection = 0;
|
||||||
}
|
}
|
||||||
|
if (fastMode == true) {
|
||||||
|
keyRepeatDelay = 3;
|
||||||
|
} else if (fastMode == false){
|
||||||
|
keyRepeatDelay = 6;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[2])) {
|
if ((hHeld & KEY_UP && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[0]))) {
|
||||||
fileInfo.clear();
|
if (selection > 0) {
|
||||||
Screen::back();
|
selection--;
|
||||||
return;
|
} else {
|
||||||
|
selection = (int)fileInfo.size()-1;
|
||||||
|
}
|
||||||
|
if (fastMode == true) {
|
||||||
|
keyRepeatDelay = 3;
|
||||||
|
} else if (fastMode == false){
|
||||||
|
keyRepeatDelay = 6;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH) {
|
if (hDown & KEY_TOUCH) {
|
||||||
@@ -457,31 +459,6 @@ void ScriptList::ListSelection(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hHeld & KEY_DOWN && !keyRepeatDelay) {
|
|
||||||
if (selection < (int)fileInfo.size()-1) {
|
|
||||||
selection++;
|
|
||||||
} else {
|
|
||||||
selection = 0;
|
|
||||||
}
|
|
||||||
if (fastMode == true) {
|
|
||||||
keyRepeatDelay = 3;
|
|
||||||
} else if (fastMode == false){
|
|
||||||
keyRepeatDelay = 6;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (hHeld & KEY_UP && !keyRepeatDelay) {
|
|
||||||
if (selection > 0) {
|
|
||||||
selection--;
|
|
||||||
} else {
|
|
||||||
selection = (int)fileInfo.size()-1;
|
|
||||||
}
|
|
||||||
if (fastMode == true) {
|
|
||||||
keyRepeatDelay = 3;
|
|
||||||
} else if (fastMode == false){
|
|
||||||
keyRepeatDelay = 6;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_A) {
|
if (hDown & KEY_A) {
|
||||||
if (dirContents[selection].isDirectory) {
|
if (dirContents[selection].isDirectory) {
|
||||||
@@ -527,27 +504,38 @@ void ScriptList::ListSelection(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
|
|
||||||
void ScriptList::SelectFunction(u32 hDown, u32 hHeld, touchPosition touch) {
|
void ScriptList::SelectFunction(u32 hDown, u32 hHeld, touchPosition touch) {
|
||||||
if (keyRepeatDelay) keyRepeatDelay--;
|
if (keyRepeatDelay) keyRepeatDelay--;
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[0])) {
|
|
||||||
if (selection2 > 0) {
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
selection2--;
|
selection2 = 0;
|
||||||
} else {
|
fileInfo2.clear();
|
||||||
selection2 = (int)fileInfo2.size()-1;
|
isScriptSelected = false;
|
||||||
}
|
mode = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[1])) {
|
if ((hHeld & KEY_DOWN && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[1]))) {
|
||||||
if (selection2 < (int)fileInfo2.size()-1) {
|
if (selection2 < (int)fileInfo2.size()-1) {
|
||||||
selection2++;
|
selection2++;
|
||||||
} else {
|
} else {
|
||||||
selection2 = 0;
|
selection2 = 0;
|
||||||
}
|
}
|
||||||
|
if (fastMode == true) {
|
||||||
|
keyRepeatDelay = 3;
|
||||||
|
} else if (fastMode == false){
|
||||||
|
keyRepeatDelay = 6;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[2])) {
|
if ((hHeld & KEY_UP && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[0]))) {
|
||||||
selection2 = 0;
|
if (selection2 > 0) {
|
||||||
fileInfo2.clear();
|
selection2--;
|
||||||
isScriptSelected = false;
|
} else {
|
||||||
mode = 0;
|
selection2 = (int)fileInfo2.size()-1;
|
||||||
|
}
|
||||||
|
if (fastMode == true) {
|
||||||
|
keyRepeatDelay = 3;
|
||||||
|
} else if (fastMode == false){
|
||||||
|
keyRepeatDelay = 6;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH) {
|
if (hDown & KEY_TOUCH) {
|
||||||
@@ -572,32 +560,6 @@ void ScriptList::SelectFunction(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hHeld & KEY_DOWN && !keyRepeatDelay) {
|
|
||||||
if (selection2 < (int)fileInfo2.size()-1) {
|
|
||||||
selection2++;
|
|
||||||
} else {
|
|
||||||
selection2 = 0;
|
|
||||||
}
|
|
||||||
if (fastMode == true) {
|
|
||||||
keyRepeatDelay = 3;
|
|
||||||
} else if (fastMode == false){
|
|
||||||
keyRepeatDelay = 6;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hHeld & KEY_UP && !keyRepeatDelay) {
|
|
||||||
if (selection2 > 0) {
|
|
||||||
selection2--;
|
|
||||||
} else {
|
|
||||||
selection2 = (int)fileInfo2.size()-1;
|
|
||||||
}
|
|
||||||
if (fastMode == true) {
|
|
||||||
keyRepeatDelay = 3;
|
|
||||||
} else if (fastMode == false){
|
|
||||||
keyRepeatDelay = 6;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_A) {
|
if (hDown & KEY_A) {
|
||||||
if (fileInfo2.size() != 0) {
|
if (fileInfo2.size() != 0) {
|
||||||
choice = fileInfo2[selection2];
|
choice = fileInfo2[selection2];
|
||||||
@@ -623,13 +585,6 @@ void ScriptList::SelectFunction(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
Config::save();
|
Config::save();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_B) {
|
|
||||||
selection2 = 0;
|
|
||||||
fileInfo2.clear();
|
|
||||||
isScriptSelected = false;
|
|
||||||
mode = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Config::viewMode == 0) {
|
if (Config::viewMode == 0) {
|
||||||
if(selection2 < screenPos2) {
|
if(selection2 < screenPos2) {
|
||||||
screenPos2 = selection2;
|
screenPos2 = selection2;
|
||||||
@@ -653,7 +608,7 @@ void ScriptList::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
SelectFunction(hDown, hHeld, touch);
|
SelectFunction(hDown, hHeld, touch);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_X || hDown & KEY_TOUCH && touching(touch, arrowPos[3])) {
|
if ((hDown & KEY_X) || (hDown & KEY_TOUCH && touching(touch, arrowPos[3]))) {
|
||||||
if (Config::viewMode == 0) {
|
if (Config::viewMode == 0) {
|
||||||
Config::viewMode = 1;
|
Config::viewMode = 1;
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
+38
-72
@@ -137,23 +137,23 @@ void Settings::DrawColorChanging(void) const {
|
|||||||
Gui::DrawArrow(0, 0, 0, 1);
|
Gui::DrawArrow(0, 0, 0, 1);
|
||||||
Gui::DrawArrow(318, 22, 180.0, 1);
|
Gui::DrawArrow(318, 22, 180.0, 1);
|
||||||
|
|
||||||
for (int i = 0; i < 7; i++) {
|
for (int i = 0; i < 8; i++) {
|
||||||
if (colorMode == i) {
|
if (colorMode == i) {
|
||||||
Gui::Draw_Rect(54 + i * 25, 2, 16, 16, C2D_Color32(140, 140, 140, 255));
|
Gui::Draw_Rect(54 + i * 25, 2, 16, 16, C2D_Color32(140, 140, 140, 255));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Gui::DrawString(58 + 0 * 25, 2, 0.5f, WHITE, "1", 400);
|
for (int i = 0; i < 8; i++) {
|
||||||
Gui::DrawString(58 + 1 * 25, 2, 0.5f, WHITE, "2", 400);
|
Gui::DrawString(58 + i * 25, 2, 0.5f, WHITE, std::to_string(i+1), 400);
|
||||||
Gui::DrawString(58 + 2 * 25, 2, 0.5f, WHITE, "3", 400);
|
}
|
||||||
Gui::DrawString(58 + 3 * 25, 2, 0.5f, WHITE, "4", 400);
|
|
||||||
Gui::DrawString(58 + 4 * 25, 2, 0.5f, WHITE, "5", 400);
|
|
||||||
Gui::DrawString(58 + 5 * 25, 2, 0.5f, WHITE, "6", 400);
|
|
||||||
Gui::DrawString(58 + 6 * 25, 2, 0.5f, WHITE, "7", 400);
|
|
||||||
|
|
||||||
Gui::Draw_Rect(buttons[0].x, buttons[0].y, 95, 41, C2D_Color32(255, 0, 0, 255));
|
if (colorMode != 7) {
|
||||||
Gui::Draw_Rect(buttons[1].x, buttons[1].y, 95, 41, C2D_Color32(0, 255, 0, 255));
|
Gui::Draw_Rect(buttons[0].x, buttons[0].y, 95, 41, C2D_Color32(255, 0, 0, 255));
|
||||||
Gui::Draw_Rect(buttons[2].x, buttons[2].y, 95, 41, C2D_Color32(0, 0, 255, 255));
|
Gui::Draw_Rect(buttons[1].x, buttons[1].y, 95, 41, C2D_Color32(0, 255, 0, 255));
|
||||||
|
Gui::Draw_Rect(buttons[2].x, buttons[2].y, 95, 41, C2D_Color32(0, 0, 255, 255));
|
||||||
|
} else {
|
||||||
|
Gui::Draw_Rect(buttons[1].x, buttons[1].y, 95, 41, Config::Color1);
|
||||||
|
}
|
||||||
|
|
||||||
if (colorMode == 0) {
|
if (colorMode == 0) {
|
||||||
Gui::DrawStringCentered(0, 60, 0.7f, Config::TxtColor, Lang::get("BAR_COLOR"), 320);
|
Gui::DrawStringCentered(0, 60, 0.7f, Config::TxtColor, Lang::get("BAR_COLOR"), 320);
|
||||||
@@ -190,6 +190,10 @@ void Settings::DrawColorChanging(void) const {
|
|||||||
Gui::DrawString(40, 98, 0.7f, WHITE, ColorHelper::getColorName(Config::progressbarColor, 2).c_str(), 400);
|
Gui::DrawString(40, 98, 0.7f, WHITE, ColorHelper::getColorName(Config::progressbarColor, 2).c_str(), 400);
|
||||||
Gui::DrawString(140, 98, 0.7f, WHITE, ColorHelper::getColorName(Config::progressbarColor, 1).c_str(), 400);
|
Gui::DrawString(140, 98, 0.7f, WHITE, ColorHelper::getColorName(Config::progressbarColor, 1).c_str(), 400);
|
||||||
Gui::DrawString(245, 98, 0.7f, WHITE, ColorHelper::getColorName(Config::progressbarColor, 0).c_str(), 400);
|
Gui::DrawString(245, 98, 0.7f, WHITE, ColorHelper::getColorName(Config::progressbarColor, 0).c_str(), 400);
|
||||||
|
} else if (colorMode == 7) {
|
||||||
|
Gui::DrawStringCentered(0, 60, 0.7f, Config::TxtColor, Lang::get("USE_BARS"), 320);
|
||||||
|
if (Config::UseBars == true) Gui::DrawString(140, 98, 0.7f, WHITE, Lang::get("YES"), 400);
|
||||||
|
else if (Config::UseBars == false) Gui::DrawString(140, 98, 0.7f, WHITE, Lang::get("NO"), 400);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -249,26 +253,25 @@ void Settings::DrawMiscSettings(void) const {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Gui::DrawStringCentered(0, mainButtons[0].y+10, 0.6f, Config::TxtColor, Lang::get("CHANGE_BARS"), 140);
|
Gui::DrawStringCentered(0, mainButtons[0].y+10, 0.6f, Config::TxtColor, Lang::get("CHANGE_STOREPATH"), 140);
|
||||||
Gui::DrawStringCentered(0, mainButtons[1].y+10, 0.6f, Config::TxtColor, Lang::get("CHANGE_SCRIPTPATH"), 140);
|
Gui::DrawStringCentered(0, mainButtons[1].y+10, 0.6f, Config::TxtColor, Lang::get("CHANGE_SCRIPTPATH"), 140);
|
||||||
Gui::DrawStringCentered(0, mainButtons[2].y+10, 0.6f, Config::TxtColor, Lang::get("CHANGE_MUSICFILE"), 140);
|
Gui::DrawStringCentered(0, mainButtons[2].y+10, 0.6f, Config::TxtColor, Lang::get("CHANGE_MUSICFILE"), 140);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Settings::MiscSettingsLogic(u32 hDown, u32 hHeld, touchPosition touch) {
|
void Settings::MiscSettingsLogic(u32 hDown, u32 hHeld, touchPosition touch) {
|
||||||
if (hDown & KEY_UP) {
|
if (hDown & KEY_UP) {
|
||||||
if(Selection > 0) Selection--;
|
if (Selection > 0) Selection--;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_DOWN) {
|
if (hDown & KEY_DOWN) {
|
||||||
if(Selection < 2) Selection++;
|
if (Selection < 2) Selection++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_A) {
|
if (hDown & KEY_A) {
|
||||||
if (Selection == 0) {
|
if (Selection == 0) {
|
||||||
if (Config::UseBars == true) {
|
std::string tempStore = selectFilePath(Lang::get("SELECT_STORE_PATH"), {});
|
||||||
Config::UseBars = false;
|
if (tempStore != "") {
|
||||||
} else if (Config::UseBars == false) {
|
Config::StorePath = tempStore;
|
||||||
Config::UseBars = true;
|
|
||||||
}
|
}
|
||||||
} else if (Selection == 1) {
|
} else if (Selection == 1) {
|
||||||
std::string tempScript = selectFilePath(Lang::get("SELECT_SCRIPT_PATH"), {});
|
std::string tempScript = selectFilePath(Lang::get("SELECT_SCRIPT_PATH"), {});
|
||||||
@@ -285,10 +288,9 @@ void Settings::MiscSettingsLogic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
|
|
||||||
if (hDown & KEY_TOUCH) {
|
if (hDown & KEY_TOUCH) {
|
||||||
if (touching(touch, mainButtons[0])) {
|
if (touching(touch, mainButtons[0])) {
|
||||||
if (Config::UseBars == true) {
|
std::string tempStore = selectFilePath(Lang::get("SELECT_STORE_PATH"), {});
|
||||||
Config::UseBars = false;
|
if (tempStore != "") {
|
||||||
} else if (Config::UseBars == false) {
|
Config::StorePath = tempStore;
|
||||||
Config::UseBars = true;
|
|
||||||
}
|
}
|
||||||
} else if (touching(touch, mainButtons[1])) {
|
} else if (touching(touch, mainButtons[1])) {
|
||||||
std::string tempScript = selectFilePath(Lang::get("SELECT_SCRIPT_PATH"), {});
|
std::string tempScript = selectFilePath(Lang::get("SELECT_SCRIPT_PATH"), {});
|
||||||
@@ -303,11 +305,7 @@ void Settings::MiscSettingsLogic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_B || hDown & KEY_L) {
|
if ((hDown & KEY_B || hDown & KEY_L) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
mode = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[2])) {
|
|
||||||
mode = 0;
|
mode = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -323,17 +321,7 @@ void Settings::SubMenuLogic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_A) {
|
if (hDown & KEY_A) {
|
||||||
switch(Selection) {
|
mode = Selection+1;
|
||||||
case 0:
|
|
||||||
mode = 1;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
mode = 2;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
mode = 3;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH) {
|
if (hDown & KEY_TOUCH) {
|
||||||
@@ -346,21 +334,12 @@ void Settings::SubMenuLogic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_B) {
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
Screen::back();
|
Screen::back();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[2])) {
|
if ((hDown & KEY_R) || (hDown & KEY_TOUCH && touching(touch, arrowPos[4]))) {
|
||||||
Screen::back();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[4])) {
|
|
||||||
mode = 4;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_R) {
|
|
||||||
mode = 4;
|
mode = 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -410,11 +389,7 @@ void Settings::LanguageSelection(u32 hDown, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_B) {
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
mode = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[2])) {
|
|
||||||
mode = 0;
|
mode = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -426,7 +401,7 @@ void Settings::colorChanging(u32 hDown, touchPosition touch) {
|
|||||||
int blue;
|
int blue;
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH) {
|
if (hDown & KEY_TOUCH) {
|
||||||
for (int i = 0; i < 7; i++) {
|
for (int i = 0; i < 8; i++) {
|
||||||
if(touch.px > 54 + i * 25 && touch.px < 54 + i * 25+16 && touch.py > 2 && touch.py < 2+16) {
|
if(touch.px > 54 + i * 25 && touch.px < 54 + i * 25+16 && touch.py > 2 && touch.py < 2+16) {
|
||||||
colorMode = i;
|
colorMode = i;
|
||||||
}
|
}
|
||||||
@@ -434,28 +409,16 @@ void Settings::colorChanging(u32 hDown, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (hDown & KEY_B) {
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
mode = 0;
|
mode = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[2])) {
|
if ((hDown & KEY_L || hDown & KEY_LEFT) || (hDown & KEY_TOUCH && touching(touch, arrowPos[0]))) {
|
||||||
mode = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[0])) {
|
|
||||||
if(colorMode > 0) colorMode--;
|
if(colorMode > 0) colorMode--;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_L || hDown & KEY_LEFT) {
|
if ((hDown & KEY_R || hDown & KEY_RIGHT) || (hDown & KEY_TOUCH && touching(touch, arrowPos[1]))) {
|
||||||
if(colorMode > 0) colorMode--;
|
if(colorMode < 7) colorMode++;
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[1])) {
|
|
||||||
if(colorMode < 6) colorMode++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_R || hDown & KEY_RIGHT) {
|
|
||||||
if(colorMode < 6) colorMode++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH) {
|
if (hDown & KEY_TOUCH) {
|
||||||
@@ -481,7 +444,7 @@ void Settings::colorChanging(u32 hDown, touchPosition touch) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
} else if (touching(touch, buttons[1])) {
|
} else if (touching(touch, buttons[1]) && colorMode != 7) {
|
||||||
int temp = Input::getUint(255, Lang::get("ENTER_GREEN_RGB"));
|
int temp = Input::getUint(255, Lang::get("ENTER_GREEN_RGB"));
|
||||||
if(temp != -1) {
|
if(temp != -1) {
|
||||||
green = temp;
|
green = temp;
|
||||||
@@ -521,6 +484,9 @@ void Settings::colorChanging(u32 hDown, touchPosition touch) {
|
|||||||
Config::progressbarColor = RGBA8(ColorHelper::getColorValue(Config::progressbarColor, 2), ColorHelper::getColorValue(Config::progressbarColor, 1), blue, 255);
|
Config::progressbarColor = RGBA8(ColorHelper::getColorValue(Config::progressbarColor, 2), ColorHelper::getColorValue(Config::progressbarColor, 1), blue, 255);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if (touching(touch, buttons[1]) && colorMode == 7) {
|
||||||
|
if (Config::UseBars == true) Config::UseBars = false;
|
||||||
|
else if (Config::UseBars == false) Config::UseBars = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,292 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is part of Universal-Updater
|
|
||||||
* Copyright (C) 2019 DeadPhoenix8091, Epicpkmn11, Flame, RocketRobz, StackZ, TotallyNotGuy
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*
|
|
||||||
* Additional Terms 7.b and 7.c of GPLv3 apply to this file:
|
|
||||||
* * Requiring preservation of specified reasonable legal notices or
|
|
||||||
* author attributions in that material or in the Appropriate Legal
|
|
||||||
* Notices displayed by works containing it.
|
|
||||||
* * Prohibiting misrepresentation of the origin of that material,
|
|
||||||
* or requiring that modified versions of such material be marked in
|
|
||||||
* reasonable ways as different from the original version.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "download/download.hpp"
|
|
||||||
|
|
||||||
#include "screens/tinyDB.hpp"
|
|
||||||
|
|
||||||
#include "utils/config.hpp"
|
|
||||||
#include "utils/fileBrowse.h"
|
|
||||||
#include "utils/json.hpp"
|
|
||||||
#include "utils/formatting.hpp"
|
|
||||||
#include "utils/scriptHelper.hpp"
|
|
||||||
|
|
||||||
extern bool touching(touchPosition touch, Structs::ButtonPos button);
|
|
||||||
#define ENTRIES_PER_SCREEN 3
|
|
||||||
#define ENTRIES_PER_LIST 7
|
|
||||||
|
|
||||||
// JSON file for TinyDB.
|
|
||||||
nlohmann::json tinyDBJson;
|
|
||||||
std::string selectedOption;
|
|
||||||
|
|
||||||
// For the Bar Textures.
|
|
||||||
extern C2D_SpriteSheet sprites;
|
|
||||||
|
|
||||||
#define tinyDBFile "sdmc:/3ds/Universal-Updater/TinyDB.json"
|
|
||||||
|
|
||||||
std::string maxEntries;
|
|
||||||
|
|
||||||
// Parse the Objects.
|
|
||||||
std::vector<std::string> parseObjects() {
|
|
||||||
FILE* file = fopen(tinyDBFile, "rt");
|
|
||||||
if(!file) {
|
|
||||||
printf("File not found\n");
|
|
||||||
return {{""}};
|
|
||||||
}
|
|
||||||
tinyDBJson = nlohmann::json::parse(file, nullptr, false);
|
|
||||||
fclose(file);
|
|
||||||
|
|
||||||
std::vector<std::string> objs;
|
|
||||||
for(auto it = tinyDBJson.begin();it != tinyDBJson.end(); it++) {
|
|
||||||
if(it.key() != "info") {
|
|
||||||
objs.push_back(it.key());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return objs;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::vector<std::string> tinyDBList;
|
|
||||||
|
|
||||||
TinyDB::TinyDB() {
|
|
||||||
DisplayMsg(Lang::get("TINYDB_DOWNLOADING"));
|
|
||||||
downloadToFile("https://tinydb.eiphax.tech/api/universal-updater.json?raw=true", tinyDBFile);
|
|
||||||
tinyDBList = parseObjects();
|
|
||||||
selectedOption = tinyDBList[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
void TinyDB::Draw(void) const {
|
|
||||||
std::string entryAmount = std::to_string(selection+1) + " / " + std::to_string(tinyDBList.size());
|
|
||||||
std::string info;
|
|
||||||
Gui::setDraw(top);
|
|
||||||
Gui::Draw_Rect(0, 0, 400, 25, C2D_Color32(63, 81, 181, 255));
|
|
||||||
Gui::Draw_Rect(0, 25, 400, 190, C2D_Color32(140, 140, 140, 255));
|
|
||||||
Gui::Draw_Rect(0, 215, 400, 25, C2D_Color32(63, 81, 181, 255));
|
|
||||||
|
|
||||||
if (Config::UseBars == true) {
|
|
||||||
Gui::sprite(sprites_top_screen_top_idx, 0, 0);
|
|
||||||
Gui::sprite(sprites_top_screen_bot_idx, 0, 215);
|
|
||||||
Gui::DrawStringCentered(0, 0, 0.7f, Config::TxtColor, "TinyDB", 400);
|
|
||||||
Gui::DrawString(397-Gui::GetStringWidth(0.6f, entryAmount), 239-Gui::GetStringHeight(0.6f, entryAmount), 0.6f, Config::TxtColor, entryAmount);
|
|
||||||
} else {
|
|
||||||
Gui::DrawStringCentered(0, 2, 0.7f, Config::TxtColor, "TinyDB", 400);
|
|
||||||
Gui::DrawString(397-Gui::GetStringWidth(0.6f, entryAmount), 237-Gui::GetStringHeight(0.6f, entryAmount), 0.6f, Config::TxtColor, entryAmount);
|
|
||||||
}
|
|
||||||
|
|
||||||
Gui::DrawStringCentered(0, 35, 0.6f, Config::TxtColor, Lang::get("AUTHOR") + std::string(tinyDBJson[selectedOption]["info"]["author"]), 400);
|
|
||||||
Gui::DrawStringCentered(0, 65, 0.6f, Config::TxtColor, Lang::get("DESC") + std::string(tinyDBJson[selectedOption]["info"]["description"]), 400);
|
|
||||||
Gui::DrawStringCentered(0, 95, 0.6f, Config::TxtColor, Lang::get("RELEASE_TAG") + std::string(tinyDBJson[selectedOption]["info"]["releaseTag"]), 400);
|
|
||||||
Gui::DrawStringCentered(0, 125, 0.6f, Config::TxtColor, Lang::get("RELEASE_ID") + std::string(tinyDBJson[selectedOption]["info"]["releaseId"]), 400);
|
|
||||||
Gui::DrawStringCentered(0, 155, 0.6f, Config::TxtColor, Lang::get("TITLE_ID") + std::string(tinyDBJson[selectedOption]["info"]["titleid"]), 400);
|
|
||||||
Gui::DrawStringCentered(0, 185, 0.6f, Config::TxtColor, Lang::get("FILE_SIZE") + formatBytes(int64_t(tinyDBJson[selectedOption]["info"]["fileSize"])), 400);
|
|
||||||
|
|
||||||
|
|
||||||
Gui::setDraw(bottom);
|
|
||||||
Gui::Draw_Rect(0, 0, 320, 25, C2D_Color32(63, 81, 181, 255));
|
|
||||||
Gui::Draw_Rect(0, 25, 320, 190, C2D_Color32(140, 140, 140, 255));
|
|
||||||
Gui::Draw_Rect(0, 215, 320, 25, C2D_Color32(63, 81, 181, 255));
|
|
||||||
if (Config::UseBars == true) {
|
|
||||||
Gui::sprite(sprites_bottom_screen_top_idx, 0, 0);
|
|
||||||
Gui::sprite(sprites_bottom_screen_bot_idx, 0, 215);
|
|
||||||
}
|
|
||||||
|
|
||||||
Gui::DrawArrow(295, -1);
|
|
||||||
Gui::DrawArrow(315, 240, 180.0);
|
|
||||||
Gui::DrawArrow(0, 218, 0, 1);
|
|
||||||
Gui::spriteBlend(sprites_view_idx, arrowPos[3].x, arrowPos[3].y);
|
|
||||||
// Gui::spriteBlend(sprites_search_idx, arrowPos[4].x, arrowPos[4].y);
|
|
||||||
|
|
||||||
if (Config::viewMode == 0) {
|
|
||||||
for(int i=0;i<ENTRIES_PER_SCREEN && i<(int)tinyDBList.size();i++) {
|
|
||||||
info = tinyDBList[screenPos + i];
|
|
||||||
if(screenPos + i == selection) {
|
|
||||||
Gui::Draw_Rect(0, 40+(i*57), 320, 45, C2D_Color32(120, 192, 216, 255));
|
|
||||||
} else {
|
|
||||||
Gui::Draw_Rect(0, 40+(i*57), 320, 45, C2D_Color32(77, 118, 132, 255));
|
|
||||||
}
|
|
||||||
Gui::DrawStringCentered(0, 50+(i*57), 0.7f, WHITE, info, 320);
|
|
||||||
}
|
|
||||||
} else if (Config::viewMode == 1) {
|
|
||||||
for(int i=0;i<ENTRIES_PER_LIST && i<(int)tinyDBList.size();i++) {
|
|
||||||
info = tinyDBList[screenPosList + i];
|
|
||||||
if(screenPosList + i == selection) {
|
|
||||||
Gui::Draw_Rect(0, (i+1)*27, 320, 25, Config::SelectedColor);
|
|
||||||
} else {
|
|
||||||
Gui::Draw_Rect(0, (i+1)*27, 320, 25, Config::UnselectedColor);
|
|
||||||
}
|
|
||||||
Gui::DrawStringCentered(0, ((i+1)*27)+1, 0.7f, Config::TxtColor, info, 320);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void TinyDB::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
|
||||||
if (keyRepeatDelay) keyRepeatDelay--;
|
|
||||||
if (hDown & KEY_B) {
|
|
||||||
Screen::back();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_R) {
|
|
||||||
fastMode = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_L) {
|
|
||||||
fastMode = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[0])) {
|
|
||||||
if (selection > 0) {
|
|
||||||
selection--;
|
|
||||||
selectedOption = tinyDBList[selection];
|
|
||||||
} else {
|
|
||||||
selection = (int)tinyDBList.size()-1;
|
|
||||||
selectedOption = tinyDBList[selection];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[1])) {
|
|
||||||
if (selection < (int)tinyDBList.size()-1) {
|
|
||||||
selection++;
|
|
||||||
selectedOption = tinyDBList[selection];
|
|
||||||
} else {
|
|
||||||
selection = 0;
|
|
||||||
selectedOption = tinyDBList[selection];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH && touching(touch, arrowPos[2])) {
|
|
||||||
Screen::back();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hHeld & KEY_UP && !keyRepeatDelay) {
|
|
||||||
if (selection > 0) {
|
|
||||||
selection--;
|
|
||||||
selectedOption = tinyDBList[selection];
|
|
||||||
} else {
|
|
||||||
selection = (int)tinyDBList.size()-1;
|
|
||||||
selectedOption = tinyDBList[selection];
|
|
||||||
}
|
|
||||||
if (fastMode == true) {
|
|
||||||
keyRepeatDelay = 3;
|
|
||||||
} else if (fastMode == false){
|
|
||||||
keyRepeatDelay = 6;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hHeld & KEY_DOWN && !keyRepeatDelay) {
|
|
||||||
if (selection < (int)tinyDBList.size()-1) {
|
|
||||||
selection++;
|
|
||||||
selectedOption = tinyDBList[selection];
|
|
||||||
} else {
|
|
||||||
selection = 0;
|
|
||||||
selectedOption = tinyDBList[selection];
|
|
||||||
}
|
|
||||||
if (fastMode == true) {
|
|
||||||
keyRepeatDelay = 3;
|
|
||||||
} else if (fastMode == false){
|
|
||||||
keyRepeatDelay = 6;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Config::viewMode == 0) {
|
|
||||||
if(selection < screenPos) {
|
|
||||||
screenPos = selection;
|
|
||||||
} else if (selection > screenPos + ENTRIES_PER_SCREEN - 1) {
|
|
||||||
screenPos = selection - ENTRIES_PER_SCREEN + 1;
|
|
||||||
}
|
|
||||||
} else if (Config::viewMode == 1) {
|
|
||||||
if(selection < screenPosList) {
|
|
||||||
screenPosList = selection;
|
|
||||||
} else if (selection > screenPosList + ENTRIES_PER_LIST - 1) {
|
|
||||||
screenPosList = selection - ENTRIES_PER_LIST + 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_X || hDown & KEY_TOUCH && touching(touch, arrowPos[3])) {
|
|
||||||
if (Config::viewMode == 0) {
|
|
||||||
Config::viewMode = 1;
|
|
||||||
} else {
|
|
||||||
Config::viewMode = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_TOUCH) {
|
|
||||||
if (Config::viewMode == 0) {
|
|
||||||
for(int i=0;i<ENTRIES_PER_SCREEN && i<(int)tinyDBList.size();i++) {
|
|
||||||
if(touch.py > 40+(i*57) && touch.py < 40+(i*57)+45) {
|
|
||||||
selection = screenPos + i;
|
|
||||||
selectedOption = tinyDBList[screenPos + i];
|
|
||||||
execute();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (Config::viewMode == 1) {
|
|
||||||
for(int i=0;i<ENTRIES_PER_LIST && i<(int)tinyDBList.size();i++) {
|
|
||||||
if(touch.py > (i+1)*27 && touch.py < (i+2)*27) {
|
|
||||||
selection = screenPosList + i;
|
|
||||||
selectedOption = tinyDBList[screenPosList + i];
|
|
||||||
execute();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hDown & KEY_A) {
|
|
||||||
execute();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void TinyDB::execute() {
|
|
||||||
for(int i=0;i<(int)tinyDBJson.at(selectedOption).at("script").size();i++) {
|
|
||||||
std::string type = tinyDBJson.at(selectedOption).at("script").at(i).at("type");
|
|
||||||
if(type == "deleteFile") {
|
|
||||||
bool missing = false;
|
|
||||||
std::string file, message;
|
|
||||||
if(tinyDBJson.at(selectedOption).at("script").at(i).contains("file")) file = tinyDBJson.at(selectedOption).at("script").at(i).at("file");
|
|
||||||
else missing = true;
|
|
||||||
if(tinyDBJson.at(selectedOption).at("script").at(i).contains("message")) message = tinyDBJson.at(selectedOption).at("script").at(i).at("message");
|
|
||||||
if(!missing) ScriptHelper::removeFile(file, message);
|
|
||||||
|
|
||||||
} else if(type == "downloadFile") {
|
|
||||||
bool missing = false;
|
|
||||||
std::string file, output, message;
|
|
||||||
if(tinyDBJson.at(selectedOption).at("script").at(i).contains("file")) file = tinyDBJson.at(selectedOption).at("script").at(i).at("file");
|
|
||||||
else missing = true;
|
|
||||||
if(tinyDBJson.at(selectedOption).at("script").at(i).contains("output")) output = tinyDBJson.at(selectedOption).at("script").at(i).at("output");
|
|
||||||
else missing = true;
|
|
||||||
if(tinyDBJson.at(selectedOption).at("script").at(i).contains("message")) message = tinyDBJson.at(selectedOption).at("script").at(i).at("message");
|
|
||||||
if(!missing) ScriptHelper::downloadFile(file, output, message);
|
|
||||||
|
|
||||||
} else if(type == "installCia") {
|
|
||||||
bool missing = false;
|
|
||||||
std::string file, message;
|
|
||||||
if(tinyDBJson.at(selectedOption).at("script").at(i).contains("file")) file = tinyDBJson.at(selectedOption).at("script").at(i).at("file");
|
|
||||||
else missing = true;
|
|
||||||
if(tinyDBJson.at(selectedOption).at("script").at(i).contains("message")) message = tinyDBJson.at(selectedOption).at("script").at(i).at("message");
|
|
||||||
if(!missing) ScriptHelper::installFile(file, message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
doneMsg();
|
|
||||||
}
|
|
||||||
@@ -0,0 +1,760 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of Universal-Updater
|
||||||
|
* Copyright (C) 2019 DeadPhoenix8091, Epicpkmn11, Flame, RocketRobz, StackZ, TotallyNotGuy
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* Additional Terms 7.b and 7.c of GPLv3 apply to this file:
|
||||||
|
* * Requiring preservation of specified reasonable legal notices or
|
||||||
|
* author attributions in that material or in the Appropriate Legal
|
||||||
|
* Notices displayed by works containing it.
|
||||||
|
* * Prohibiting misrepresentation of the origin of that material,
|
||||||
|
* or requiring that modified versions of such material be marked in
|
||||||
|
* reasonable ways as different from the original version.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "keyboard.hpp"
|
||||||
|
|
||||||
|
#include "download/download.hpp"
|
||||||
|
|
||||||
|
#include "screens/unistore.hpp"
|
||||||
|
|
||||||
|
#include "utils/config.hpp"
|
||||||
|
#include "utils/fileBrowse.h"
|
||||||
|
#include "utils/formatting.hpp"
|
||||||
|
#include "utils/json.hpp"
|
||||||
|
#include "utils/scriptHelper.hpp"
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
|
#include <regex>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
extern bool touching(touchPosition touch, Structs::ButtonPos button);
|
||||||
|
extern u32 getColor(std::string colorString);
|
||||||
|
nlohmann::json appStoreJson;
|
||||||
|
std::string currentStoreFile;
|
||||||
|
extern bool isScriptSelected;
|
||||||
|
|
||||||
|
extern u32 barColor;
|
||||||
|
extern u32 bgTopColor;
|
||||||
|
extern u32 bgBottomColor;
|
||||||
|
extern u32 TextColor;
|
||||||
|
extern u32 progressBar;
|
||||||
|
extern u32 selected;
|
||||||
|
extern u32 unselected;
|
||||||
|
|
||||||
|
C2D_SpriteSheet appStoreSheet;
|
||||||
|
|
||||||
|
struct storeInfo2 {
|
||||||
|
std::string title;
|
||||||
|
std::string author;
|
||||||
|
std::string description;
|
||||||
|
std::string url;
|
||||||
|
std::string file;
|
||||||
|
std::string storeSheet;
|
||||||
|
std::string sheetURL;
|
||||||
|
};
|
||||||
|
|
||||||
|
extern void notImplemented(void);
|
||||||
|
|
||||||
|
// Parse informations like URL, Title, Author, Description.
|
||||||
|
storeInfo2 parseStoreInfo(std::string fileName) {
|
||||||
|
FILE* file = fopen(fileName.c_str(), "rt");
|
||||||
|
if(!file) {
|
||||||
|
printf("File not found\n");
|
||||||
|
return {"", ""};
|
||||||
|
}
|
||||||
|
nlohmann::json json = nlohmann::json::parse(file, nullptr, false);
|
||||||
|
fclose(file);
|
||||||
|
|
||||||
|
storeInfo2 info;
|
||||||
|
info.title = ScriptHelper::getString(json, "storeInfo", "title");
|
||||||
|
info.author = ScriptHelper::getString(json, "storeInfo", "author");
|
||||||
|
info.description = ScriptHelper::getString(json, "storeInfo", "description");
|
||||||
|
info.url = ScriptHelper::getString(json, "storeInfo", "url");
|
||||||
|
info.file = ScriptHelper::getString(json, "storeInfo", "file");
|
||||||
|
info.storeSheet = ScriptHelper::getString(json, "storeInfo", "sheet");
|
||||||
|
info.sheetURL = ScriptHelper::getString(json, "storeInfo", "sheetURL");
|
||||||
|
return info;
|
||||||
|
}
|
||||||
|
|
||||||
|
nlohmann::json openStoreFile() {
|
||||||
|
FILE* file = fopen(currentStoreFile.c_str(), "rt");
|
||||||
|
nlohmann::json jsonFile;
|
||||||
|
if(file) jsonFile = nlohmann::json::parse(file, nullptr, false);
|
||||||
|
fclose(file);
|
||||||
|
return jsonFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Parse the Objects.
|
||||||
|
std::vector<std::string> parseStoreObjects(std::string storeName) {
|
||||||
|
FILE* file = fopen(storeName.c_str(), "rt");
|
||||||
|
if(!file) {
|
||||||
|
printf("File not found\n");
|
||||||
|
return {{""}};
|
||||||
|
}
|
||||||
|
nlohmann::json json = nlohmann::json::parse(file, nullptr, false);
|
||||||
|
fclose(file);
|
||||||
|
|
||||||
|
std::vector<std::string> objs;
|
||||||
|
for(auto it = json.begin();it != json.end(); it++) {
|
||||||
|
if(it.key() != "storeInfo") {
|
||||||
|
objs.push_back(it.key());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return objs;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<storeInfo2> storeInfo; // Store selection.
|
||||||
|
std::vector<std::string> appStoreList; // Actual store. ;P
|
||||||
|
std::vector<std::string> descLines;
|
||||||
|
std::string storeDesc = "";
|
||||||
|
|
||||||
|
bool sheetHasLoaded = false;
|
||||||
|
// Sheet / Icon stuff.
|
||||||
|
void loadStoreSheet(int pos) {
|
||||||
|
appStoreSheet = C2D_SpriteSheetLoad(storeInfo[pos].storeSheet.c_str());
|
||||||
|
sheetHasLoaded = true;
|
||||||
|
}
|
||||||
|
void freeSheet() {
|
||||||
|
C2D_SpriteSheetFree(appStoreSheet);
|
||||||
|
sheetHasLoaded = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void UniStore::descript() {
|
||||||
|
if (storeInfo[selection].description != "" || storeInfo[selection].description != "MISSING: storeInfo.description") {
|
||||||
|
storeDesc = storeInfo[selection].description;
|
||||||
|
} else storeDesc = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
void loadStoreDesc(void) {
|
||||||
|
descLines.clear();
|
||||||
|
while(storeDesc.find('\n') != storeDesc.npos) {
|
||||||
|
descLines.push_back(storeDesc.substr(0, storeDesc.find('\n')));
|
||||||
|
storeDesc = storeDesc.substr(storeDesc.find('\n')+1);
|
||||||
|
}
|
||||||
|
descLines.push_back(storeDesc.substr(0, storeDesc.find('\n')));
|
||||||
|
}
|
||||||
|
|
||||||
|
UniStore::UniStore() {
|
||||||
|
dirContents.clear();
|
||||||
|
chdir(Config::StorePath.c_str());
|
||||||
|
getDirectoryContents(dirContents, {"unistore"});
|
||||||
|
for(uint i=0;i<dirContents.size();i++) {
|
||||||
|
storeInfo.push_back(parseStoreInfo(dirContents[i].name));
|
||||||
|
}
|
||||||
|
descript();
|
||||||
|
loadStoreDesc();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Store colors.
|
||||||
|
void loadStoreColors(nlohmann::json &json) {
|
||||||
|
u32 colorTemp;
|
||||||
|
colorTemp = getColor(ScriptHelper::getString(json, "storeInfo", "barColor"));
|
||||||
|
barColor = colorTemp == 0 ? Config::Color1 : colorTemp;
|
||||||
|
|
||||||
|
colorTemp = getColor(ScriptHelper::getString(json, "storeInfo", "bgTopColor"));
|
||||||
|
bgTopColor = colorTemp == 0 ? Config::Color2 : colorTemp;
|
||||||
|
|
||||||
|
colorTemp = getColor(ScriptHelper::getString(json, "storeInfo", "bgBottomColor"));
|
||||||
|
bgBottomColor = colorTemp == 0 ? Config::Color3 : colorTemp;
|
||||||
|
|
||||||
|
colorTemp = getColor(ScriptHelper::getString(json, "storeInfo", "textColor"));
|
||||||
|
TextColor = colorTemp == 0 ? Config::TxtColor : colorTemp;
|
||||||
|
|
||||||
|
colorTemp = getColor(ScriptHelper::getString(json, "storeInfo", "selectedColor"));
|
||||||
|
selected = colorTemp == 0 ? Config::SelectedColor : colorTemp;
|
||||||
|
|
||||||
|
colorTemp = getColor(ScriptHelper::getString(json, "storeInfo", "unselectedColor"));
|
||||||
|
unselected = colorTemp == 0 ? Config::UnselectedColor : colorTemp;
|
||||||
|
|
||||||
|
colorTemp = getColor(ScriptHelper::getString(json, "storeInfo", "progressbarColor"));
|
||||||
|
progressBar = colorTemp == 0 ? Config::progressbarColor : colorTemp;
|
||||||
|
}
|
||||||
|
|
||||||
|
// First Screen -> Storelist.
|
||||||
|
void UniStore::DrawStoreList(void) const {
|
||||||
|
std::string line1;
|
||||||
|
std::string line2;
|
||||||
|
std::string storeAmount = std::to_string(selection +1) + " / " + std::to_string(storeInfo.size());
|
||||||
|
Gui::DrawTop();
|
||||||
|
if (Config::UseBars == true) {
|
||||||
|
Gui::DrawStringCentered(0, 0, 0.7f, Config::TxtColor, storeInfo[selection].title, 400);
|
||||||
|
Gui::DrawString(397-Gui::GetStringWidth(0.6f, storeAmount), 239-Gui::GetStringHeight(0.6f, storeAmount), 0.6f, Config::TxtColor, storeAmount);
|
||||||
|
} else {
|
||||||
|
Gui::DrawStringCentered(0, 2, 0.7f, Config::TxtColor, storeInfo[selection].title, 400);
|
||||||
|
Gui::DrawString(397-Gui::GetStringWidth(0.6f, storeAmount), 237-Gui::GetStringHeight(0.6f, storeAmount), 0.6f, Config::TxtColor, storeAmount);
|
||||||
|
}
|
||||||
|
for(uint i=0;i<descLines.size();i++) {
|
||||||
|
Gui::DrawStringCentered(0, 120-((descLines.size()*20)/2)+i*20, 0.6f, Config::TxtColor, descLines[i], 400);
|
||||||
|
}
|
||||||
|
|
||||||
|
Gui::DrawBottom();
|
||||||
|
Gui::DrawArrow(295, -1);
|
||||||
|
Gui::DrawArrow(315, 240, 180.0);
|
||||||
|
Gui::DrawArrow(0, 218, 0, 1);
|
||||||
|
Gui::spriteBlend(sprites_view_idx, arrowPos[3].x, arrowPos[3].y);
|
||||||
|
Gui::spriteBlend(sprites_search_idx, arrowPos[4].x, arrowPos[4].y);
|
||||||
|
Gui::spriteBlend(sprites_update_idx, arrowPos[5].x, arrowPos[5].y);
|
||||||
|
|
||||||
|
if (Config::viewMode == 0) {
|
||||||
|
for(int i=0;i<ENTRIES_PER_SCREEN && i<(int)storeInfo.size();i++) {
|
||||||
|
line1 = storeInfo[screenPos + i].title;
|
||||||
|
line2 = storeInfo[screenPos + i].author;
|
||||||
|
if(screenPos + i == selection) {
|
||||||
|
Gui::Draw_Rect(0, 40+(i*57), 320, 45, Config::SelectedColor);
|
||||||
|
} else {
|
||||||
|
Gui::Draw_Rect(0, 40+(i*57), 320, 45, Config::UnselectedColor);
|
||||||
|
}
|
||||||
|
Gui::DrawStringCentered(0, 38+(i*57), 0.7f, Config::TxtColor, line1, 320);
|
||||||
|
Gui::DrawStringCentered(0, 62+(i*57), 0.7f, Config::TxtColor, line2, 320);
|
||||||
|
}
|
||||||
|
} else if (Config::viewMode == 1) {
|
||||||
|
for(int i=0;i<ENTRIES_PER_LIST && i<(int)storeInfo.size();i++) {
|
||||||
|
line1 = storeInfo[screenPosList + i].title;
|
||||||
|
if(screenPosList + i == selection) {
|
||||||
|
Gui::Draw_Rect(0, (i+1)*27, 320, 25, Config::SelectedColor);
|
||||||
|
} else {
|
||||||
|
Gui::Draw_Rect(0, (i+1)*27, 320, 25, Config::UnselectedColor);
|
||||||
|
}
|
||||||
|
Gui::DrawStringCentered(0, ((i+1)*27)+1, 0.7f, Config::TxtColor, line1, 320);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void UniStore::DrawStore(void) const {
|
||||||
|
std::string entryAmount = std::to_string(selection2+1) + " / " + std::to_string(appStoreList.size());
|
||||||
|
std::string info;
|
||||||
|
Gui::DrawTop();
|
||||||
|
if (Config::UseBars == true) {
|
||||||
|
Gui::sprite(sprites_top_screen_top_idx, 0, 0);
|
||||||
|
Gui::sprite(sprites_top_screen_bot_idx, 0, 215);
|
||||||
|
Gui::DrawStringCentered(0, 0, 0.7f, TextColor, std::string(appStoreJson["storeInfo"]["title"]), 400);
|
||||||
|
Gui::DrawString(397-Gui::GetStringWidth(0.6f, entryAmount), 239-Gui::GetStringHeight(0.6f, entryAmount), 0.6f, TextColor, entryAmount);
|
||||||
|
} else {
|
||||||
|
Gui::DrawStringCentered(0, 2, 0.7f, TextColor, std::string(appStoreJson["storeInfo"]["title"]), 400);
|
||||||
|
Gui::DrawString(397-Gui::GetStringWidth(0.6f, entryAmount), 237-Gui::GetStringHeight(0.6f, entryAmount), 0.6f, TextColor, entryAmount);
|
||||||
|
}
|
||||||
|
|
||||||
|
Gui::DrawStringCentered(0, 32, 0.6f, TextColor, Lang::get("TITLE") + std::string(appStoreList[selection2]), 400);
|
||||||
|
Gui::DrawStringCentered(0, 57, 0.6f, TextColor, Lang::get("AUTHOR") + std::string(appStoreJson[selectedOptionAppStore]["info"]["author"]), 400);
|
||||||
|
Gui::DrawStringCentered(0, 82, 0.6f, TextColor, Lang::get("DESC") + std::string(appStoreJson[selectedOptionAppStore]["info"]["description"]), 400);
|
||||||
|
|
||||||
|
if (appStoreJson[selectedOptionAppStore]["info"]["version"] != "") {
|
||||||
|
Gui::DrawStringCentered(0, 107, 0.6f, TextColor, Lang::get("VERSION") + std::string(appStoreJson[selectedOptionAppStore]["info"]["version"]), 400);
|
||||||
|
} else {
|
||||||
|
Gui::DrawStringCentered(0, 107, 0.6f, TextColor, Lang::get("VERSION") + Lang::get("UNKNOWN"), 400);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (appStoreJson[selectedOptionAppStore]["info"]["fileSize"] != 0) {
|
||||||
|
Gui::DrawStringCentered(0, 132, 0.6f, TextColor, Lang::get("FILE_SIZE") + formatBytes(int64_t(appStoreJson[selectedOptionAppStore]["info"]["fileSize"])), 400);
|
||||||
|
} else {
|
||||||
|
Gui::DrawStringCentered(0, 132, 0.6f, TextColor, Lang::get("FILE_SIZE") + Lang::get("UNKNOWN"), 400);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (appStoreJson.at(selectedOptionAppStore).at("info").contains("iconIndex") && sheetHasLoaded == true) {
|
||||||
|
if (appStoreJson.at(selectedOptionAppStore).at("info").contains("posX") && appStoreJson.at(selectedOptionAppStore).at("info").contains("posY")) {
|
||||||
|
C2D_DrawImageAt(C2D_SpriteSheetGetImage(appStoreSheet, appStoreJson[selectedOptionAppStore]["info"]["iconIndex"]), appStoreJson[selectedOptionAppStore]["info"]["posX"], appStoreJson[selectedOptionAppStore]["info"]["posY"], 0.5f, NULL);
|
||||||
|
} else {
|
||||||
|
C2D_DrawImageAt(C2D_SpriteSheetGetImage(appStoreSheet, appStoreJson[selectedOptionAppStore]["info"]["iconIndex"]), 175, 155, 0.5f, NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Gui::DrawBottom();
|
||||||
|
Gui::DrawArrow(295, -1);
|
||||||
|
Gui::DrawArrow(315, 240, 180.0);
|
||||||
|
Gui::DrawArrow(0, 218, 0, 1);
|
||||||
|
Gui::spriteBlend(sprites_view_idx, arrowPos[3].x, arrowPos[3].y);
|
||||||
|
|
||||||
|
if (Config::viewMode == 0) {
|
||||||
|
for(int i=0;i<ENTRIES_PER_SCREEN && i<(int)appStoreList.size();i++) {
|
||||||
|
info = appStoreList[screenPos2 + i];
|
||||||
|
if(screenPos2 + i == selection2) {
|
||||||
|
Gui::Draw_Rect(0, 40+(i*57), 320, 45, selected);
|
||||||
|
} else {
|
||||||
|
Gui::Draw_Rect(0, 40+(i*57), 320, 45, unselected);
|
||||||
|
}
|
||||||
|
Gui::DrawStringCentered(0, 50+(i*57), 0.7f, TextColor, info, 320);
|
||||||
|
}
|
||||||
|
} else if (Config::viewMode == 1) {
|
||||||
|
for(int i=0;i<ENTRIES_PER_LIST && i<(int)appStoreList.size();i++) {
|
||||||
|
info = appStoreList[screenPosList2 + i];
|
||||||
|
if(screenPosList2 + i == selection2) {
|
||||||
|
Gui::Draw_Rect(0, (i+1)*27, 320, 25, selected);
|
||||||
|
} else {
|
||||||
|
Gui::Draw_Rect(0, (i+1)*27, 320, 25, unselected);
|
||||||
|
}
|
||||||
|
Gui::DrawStringCentered(0, ((i+1)*27)+1, 0.7f, TextColor, info, 320);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void UniStore::Draw(void) const {
|
||||||
|
if (mode == 0) {
|
||||||
|
DrawStoreList();
|
||||||
|
} else if (mode == 1) {
|
||||||
|
DrawStore();
|
||||||
|
} else if (mode == 2) {
|
||||||
|
DrawSearch();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void UniStore::StoreSelectionLogic(u32 hDown, u32 hHeld, touchPosition touch) {
|
||||||
|
if (keyRepeatDelay) keyRepeatDelay--;
|
||||||
|
|
||||||
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
|
storeInfo.clear();
|
||||||
|
Screen::back();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Download / search screen.
|
||||||
|
if (hDown & KEY_TOUCH && touching(touch, arrowPos[4])) {
|
||||||
|
mode = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((hHeld & KEY_DOWN && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[1]))) {
|
||||||
|
if (selection < (int)storeInfo.size()-1) {
|
||||||
|
selection++;
|
||||||
|
descript();
|
||||||
|
loadStoreDesc();
|
||||||
|
} else {
|
||||||
|
selection = 0;
|
||||||
|
descript();
|
||||||
|
loadStoreDesc();
|
||||||
|
}
|
||||||
|
if (fastMode == true) {
|
||||||
|
keyRepeatDelay = 3;
|
||||||
|
} else if (fastMode == false){
|
||||||
|
keyRepeatDelay = 6;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ((hHeld & KEY_UP && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[0]))) {
|
||||||
|
if (selection > 0) {
|
||||||
|
selection--;
|
||||||
|
descript();
|
||||||
|
loadStoreDesc();
|
||||||
|
} else {
|
||||||
|
selection = (int)storeInfo.size()-1;
|
||||||
|
descript();
|
||||||
|
loadStoreDesc();
|
||||||
|
}
|
||||||
|
if (fastMode == true) {
|
||||||
|
keyRepeatDelay = 3;
|
||||||
|
} else if (fastMode == false){
|
||||||
|
keyRepeatDelay = 6;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((hDown & KEY_Y) || (hDown & KEY_TOUCH && touching(touch, arrowPos[5]))) {
|
||||||
|
if (Gui::promptMsg(Lang::get("WOULD_YOU_LIKE_UPDATE"))) {
|
||||||
|
if(storeInfo[selection].url != "" && storeInfo[selection].url != "MISSING: storeInfo.url" &&
|
||||||
|
storeInfo[selection].file != "" && storeInfo[selection].file != "MISSING: storeInfo.file") {
|
||||||
|
ScriptHelper::downloadFile(storeInfo[selection].url, storeInfo[selection].file, Lang::get("UPDATING"));
|
||||||
|
}
|
||||||
|
if(storeInfo[selection].sheetURL != "" && storeInfo[selection].sheetURL != "MISSING: storeInfo.sheetURL" &&
|
||||||
|
storeInfo[selection].storeSheet != "" && storeInfo[selection].storeSheet != "MISSING: storeInfo.sheet") {
|
||||||
|
ScriptHelper::downloadFile(storeInfo[selection].sheetURL, storeInfo[selection].storeSheet, Lang::get("UPDATING"));
|
||||||
|
}
|
||||||
|
// Refresh the list.
|
||||||
|
dirContents.clear();
|
||||||
|
storeInfo.clear();
|
||||||
|
chdir(Config::StorePath.c_str());
|
||||||
|
getDirectoryContents(dirContents, {"unistore"});
|
||||||
|
for(uint i=0;i<dirContents.size();i++) {
|
||||||
|
storeInfo.push_back(parseStoreInfo(dirContents[i].name));
|
||||||
|
descript();
|
||||||
|
loadStoreDesc();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hDown & KEY_A) {
|
||||||
|
if (dirContents[selection].isDirectory) {
|
||||||
|
} else if (storeInfo.size() != 0) {
|
||||||
|
if (ScriptHelper::checkIfValid(dirContents[selection].name, 1) == true) {
|
||||||
|
currentStoreFile = dirContents[selection].name;
|
||||||
|
DisplayMsg(Lang::get("PREPARE_STORE"));
|
||||||
|
if (storeInfo[selection].storeSheet != "" || storeInfo[selection].storeSheet != "MISSING: storeInfo.sheet") {
|
||||||
|
if(access(storeInfo[selection].storeSheet.c_str(), F_OK) != -1 ) {
|
||||||
|
loadStoreSheet(selection);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
appStoreJson = openStoreFile();
|
||||||
|
appStoreList = parseStoreObjects(currentStoreFile);
|
||||||
|
loadStoreColors(appStoreJson);
|
||||||
|
selectedOptionAppStore = appStoreList[0];
|
||||||
|
isScriptSelected = true;
|
||||||
|
mode = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hDown & KEY_R) {
|
||||||
|
fastMode = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hDown & KEY_L) {
|
||||||
|
fastMode = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Config::viewMode == 0) {
|
||||||
|
if(selection < screenPos) {
|
||||||
|
screenPos = selection;
|
||||||
|
} else if (selection > screenPos + ENTRIES_PER_SCREEN - 1) {
|
||||||
|
screenPos = selection - ENTRIES_PER_SCREEN + 1;
|
||||||
|
}
|
||||||
|
} else if (Config::viewMode == 1) {
|
||||||
|
if(selection < screenPosList) {
|
||||||
|
screenPosList = selection;
|
||||||
|
} else if (selection > screenPosList + ENTRIES_PER_LIST - 1) {
|
||||||
|
screenPosList = selection - ENTRIES_PER_LIST + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hDown & KEY_TOUCH) {
|
||||||
|
if (Config::viewMode == 0) {
|
||||||
|
for(int i=0;i<ENTRIES_PER_SCREEN && i<(int)storeInfo.size();i++) {
|
||||||
|
if(touch.py > 40+(i*57) && touch.py < 40+(i*57)+45) {
|
||||||
|
if (ScriptHelper::checkIfValid(dirContents[screenPos + i].name, 1) == true) {
|
||||||
|
currentStoreFile = dirContents[screenPos + i].name;
|
||||||
|
DisplayMsg(Lang::get("PREPARE_STORE"));
|
||||||
|
if (storeInfo[screenPos + i].storeSheet != "" || storeInfo[screenPos + i].storeSheet != "MISSING: storeInfo.sheet") {
|
||||||
|
if(access(storeInfo[screenPos + i].storeSheet.c_str(), F_OK) != -1 ) {
|
||||||
|
loadStoreSheet(screenPos + i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
appStoreJson = openStoreFile();
|
||||||
|
appStoreList = parseStoreObjects(currentStoreFile);
|
||||||
|
loadStoreColors(appStoreJson);
|
||||||
|
selectedOptionAppStore = appStoreList[0];
|
||||||
|
isScriptSelected = true;
|
||||||
|
mode = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (Config::viewMode == 1) {
|
||||||
|
for(int i=0;i<ENTRIES_PER_LIST && i<(int)storeInfo.size();i++) {
|
||||||
|
if(touch.py > (i+1)*27 && touch.py < (i+2)*27) {
|
||||||
|
if (ScriptHelper::checkIfValid(dirContents[screenPosList + i].name, 1) == true) {
|
||||||
|
currentStoreFile = dirContents[screenPosList + i].name;
|
||||||
|
DisplayMsg(Lang::get("PREPARE_STORE"));
|
||||||
|
if (storeInfo[screenPosList + i].storeSheet != "" || storeInfo[screenPosList + i].storeSheet != "MISSING: storeInfo.sheet") {
|
||||||
|
if(access(storeInfo[screenPosList + i].storeSheet.c_str(), F_OK) != -1 ) {
|
||||||
|
loadStoreSheet(screenPosList + i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
appStoreJson = openStoreFile();
|
||||||
|
appStoreList = parseStoreObjects(currentStoreFile);
|
||||||
|
loadStoreColors(appStoreJson);
|
||||||
|
selectedOptionAppStore = appStoreList[0];
|
||||||
|
isScriptSelected = true;
|
||||||
|
mode = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void UniStore::StoreLogic(u32 hDown, u32 hHeld, touchPosition touch) {
|
||||||
|
if (keyRepeatDelay) keyRepeatDelay--;
|
||||||
|
|
||||||
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
|
mode = 0;
|
||||||
|
appStoreList.clear();
|
||||||
|
isScriptSelected = false;
|
||||||
|
selection2 = 0;
|
||||||
|
if (sheetHasLoaded == true) {
|
||||||
|
freeSheet();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hDown & KEY_R) {
|
||||||
|
fastMode = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hDown & KEY_L) {
|
||||||
|
fastMode = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Go one entry up.
|
||||||
|
if ((hHeld & KEY_UP && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[0]))) {
|
||||||
|
if (selection2 > 0) {
|
||||||
|
selection2--;
|
||||||
|
selectedOptionAppStore = appStoreList[selection2];
|
||||||
|
} else {
|
||||||
|
selection2 = (int)appStoreList.size()-1;
|
||||||
|
selectedOptionAppStore = appStoreList[selection2];
|
||||||
|
}
|
||||||
|
if (fastMode == true) {
|
||||||
|
keyRepeatDelay = 3;
|
||||||
|
} else if (fastMode == false){
|
||||||
|
keyRepeatDelay = 6;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Go one entry down.
|
||||||
|
if ((hHeld & KEY_DOWN && !keyRepeatDelay) || (hDown & KEY_TOUCH && touching(touch, arrowPos[1]))) {
|
||||||
|
if (selection2 < (int)appStoreList.size()-1) {
|
||||||
|
selection2++;
|
||||||
|
selectedOptionAppStore = appStoreList[selection2];
|
||||||
|
} else {
|
||||||
|
selection2 = 0;
|
||||||
|
selectedOptionAppStore = appStoreList[selection2];
|
||||||
|
}
|
||||||
|
if (fastMode == true) {
|
||||||
|
keyRepeatDelay = 3;
|
||||||
|
} else if (fastMode == false){
|
||||||
|
keyRepeatDelay = 6;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Execute touched Entry.
|
||||||
|
if (hDown & KEY_TOUCH) {
|
||||||
|
if (Config::viewMode == 0) {
|
||||||
|
for(int i=0;i<ENTRIES_PER_SCREEN && i<(int)appStoreList.size();i++) {
|
||||||
|
if(touch.py > 40+(i*57) && touch.py < 40+(i*57)+45) {
|
||||||
|
selection2 = screenPos2 + i;
|
||||||
|
selectedOptionAppStore = appStoreList[screenPos2 + i];
|
||||||
|
execute();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (Config::viewMode == 1) {
|
||||||
|
for(int i=0;i<ENTRIES_PER_LIST && i<(int)appStoreList.size();i++) {
|
||||||
|
if(touch.py > (i+1)*27 && touch.py < (i+2)*27) {
|
||||||
|
selection2 = screenPosList2 + i;
|
||||||
|
selectedOptionAppStore = appStoreList[screenPosList2 + i];
|
||||||
|
execute();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Execute that Entry.
|
||||||
|
if (hDown & KEY_A) {
|
||||||
|
execute();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Config::viewMode == 0) {
|
||||||
|
if(selection2 < screenPos2) {
|
||||||
|
screenPos2 = selection2;
|
||||||
|
} else if (selection2 > screenPos2 + ENTRIES_PER_SCREEN - 1) {
|
||||||
|
screenPos2 = selection2 - ENTRIES_PER_SCREEN + 1;
|
||||||
|
}
|
||||||
|
} else if (Config::viewMode == 1) {
|
||||||
|
if(selection2 < screenPosList2) {
|
||||||
|
screenPosList2 = selection2;
|
||||||
|
} else if (selection2 > screenPosList2 + ENTRIES_PER_LIST - 1) {
|
||||||
|
screenPosList2 = selection2 - ENTRIES_PER_LIST + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void UniStore::Logic(u32 hDown, u32 hHeld, touchPosition touch) {
|
||||||
|
if (mode == 0) {
|
||||||
|
StoreSelectionLogic(hDown, hHeld, touch);
|
||||||
|
} else if (mode == 1) {
|
||||||
|
StoreLogic(hDown, hHeld, touch);
|
||||||
|
} else if (mode == 2) {
|
||||||
|
SearchLogic(hDown, hHeld, touch);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Switch ViewMode.
|
||||||
|
if (((mode != 2) && (hDown & KEY_X)) || ((mode != 2) && (hDown & KEY_TOUCH && touching(touch, arrowPos[3])))) {
|
||||||
|
if (Config::viewMode == 0) {
|
||||||
|
Config::viewMode = 1;
|
||||||
|
} else {
|
||||||
|
Config::viewMode = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Execute Entry.
|
||||||
|
void UniStore::execute() {
|
||||||
|
for(int i=0;i<(int)appStoreJson.at(selectedOptionAppStore).at("script").size();i++) {
|
||||||
|
std::string type = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("type");
|
||||||
|
if(type == "deleteFile") {
|
||||||
|
bool missing = false;
|
||||||
|
std::string file, message;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("file")) file = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("file");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("message")) message = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("message");
|
||||||
|
if(!missing) ScriptHelper::removeFile(file, message);
|
||||||
|
|
||||||
|
} else if(type == "downloadFile") {
|
||||||
|
bool missing = false;
|
||||||
|
std::string file, output, message;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("file")) file = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("file");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("output")) output = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("output");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("message")) message = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("message");
|
||||||
|
if(!missing) ScriptHelper::downloadFile(file, output, message);
|
||||||
|
|
||||||
|
} else if(type == "downloadRelease") {
|
||||||
|
bool missing = false, includePrereleases = false;
|
||||||
|
std::string repo, file, output, message;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("repo")) repo = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("repo");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("file")) file = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("file");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("output")) output = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("output");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("includePrereleases") && appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("includePrereleases").is_boolean())
|
||||||
|
includePrereleases = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("includePrereleases");
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("message")) message = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("message");
|
||||||
|
if(!missing) ScriptHelper::downloadRelease(repo, file, output, includePrereleases, message);
|
||||||
|
|
||||||
|
} else if(type == "extractFile") {
|
||||||
|
bool missing = false;
|
||||||
|
std::string file, input, output, message;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("file")) file = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("file");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("input")) input = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("input");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("output")) output = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("output");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("message")) message = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("message");
|
||||||
|
if(!missing) ScriptHelper::extractFile(file, input, output, message);
|
||||||
|
|
||||||
|
} else if(type == "installCia") {
|
||||||
|
bool missing = false;
|
||||||
|
std::string file, message;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("file")) file = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("file");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("message")) message = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("message");
|
||||||
|
if(!missing) ScriptHelper::installFile(file, message);
|
||||||
|
|
||||||
|
} else if (type == "mkdir") {
|
||||||
|
bool missing = false;
|
||||||
|
std::string directory, message;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("directory")) directory = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("directory");
|
||||||
|
else missing = true;
|
||||||
|
if(!missing) makeDirs(directory.c_str());
|
||||||
|
|
||||||
|
} else if (type == "rmdir") {
|
||||||
|
bool missing = false;
|
||||||
|
std::string directory, message, promptmsg;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("directory")) directory = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("directory");
|
||||||
|
else missing = true;
|
||||||
|
promptmsg = Lang::get("DELETE_PROMPT") + "\n" + directory;
|
||||||
|
if(!missing) {
|
||||||
|
if (Gui::promptMsg(promptmsg)) {
|
||||||
|
removeDirRecursive(directory.c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if (type == "mkfile") {
|
||||||
|
bool missing = false;
|
||||||
|
std::string file;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("file")) file = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("file");
|
||||||
|
else missing = true;
|
||||||
|
if(!missing) ScriptHelper::createFile(file.c_str());
|
||||||
|
|
||||||
|
} else if (type == "timeMsg") {
|
||||||
|
bool missing = false;
|
||||||
|
std::string message;
|
||||||
|
int seconds;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("message")) message = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("message");
|
||||||
|
else missing = true;
|
||||||
|
if(appStoreJson.at(selectedOptionAppStore).at("script").at(i).contains("seconds") && appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("seconds").is_number())
|
||||||
|
seconds = appStoreJson.at(selectedOptionAppStore).at("script").at(i).at("seconds");
|
||||||
|
else missing = true;
|
||||||
|
if(!missing) ScriptHelper::displayTimeMsg(message, seconds);
|
||||||
|
} else if (type == "saveConfig") {
|
||||||
|
Config::save();
|
||||||
|
} else if (type == "notImplemented") {
|
||||||
|
notImplemented();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
doneMsg();
|
||||||
|
}
|
||||||
|
|
||||||
|
void UniStore::DrawSearch(void) const {
|
||||||
|
Gui::DrawTop();
|
||||||
|
if (Config::UseBars == true) {
|
||||||
|
Gui::DrawStringCentered(0, 0, 0.7f, Config::TxtColor, Lang::get("UNISTORE_SEARCH"), 400);
|
||||||
|
} else {
|
||||||
|
Gui::DrawStringCentered(0, 2, 0.7f, Config::TxtColor, Lang::get("UNISTORE_SEARCH"), 400);
|
||||||
|
}
|
||||||
|
|
||||||
|
Gui::sprite(sprites_uniStore_HD_idx, 140, 50, 0.2, 0.2);
|
||||||
|
Gui::DrawBottom();
|
||||||
|
Gui::DrawArrow(0, 218, 0, 1);
|
||||||
|
|
||||||
|
for (int i = 0; i < 2; i++) {
|
||||||
|
if (searchSelection == i) {
|
||||||
|
Gui::Draw_Rect(URLBtn[i].x, URLBtn[i].y, URLBtn[i].w, URLBtn[i].h, Config::SelectedColor);
|
||||||
|
} else {
|
||||||
|
Gui::Draw_Rect(URLBtn[i].x, URLBtn[i].y, URLBtn[i].w, URLBtn[i].h, Config::UnselectedColor);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("FULL_URL")))/2-150+70, 110, 0.6f, Config::TxtColor, Lang::get("FULL_URL"), 140);
|
||||||
|
Gui::DrawString((320-Gui::GetStringWidth(0.6f, Lang::get("GITHUB")))/2+150-70, 110, 0.6f, Config::TxtColor, Lang::get("GITHUB"), 140);
|
||||||
|
}
|
||||||
|
|
||||||
|
void UniStore::SearchLogic(u32 hDown, u32 hHeld, touchPosition touch) {
|
||||||
|
if ((hDown & KEY_B) || (hDown & KEY_TOUCH && touching(touch, arrowPos[2]))) {
|
||||||
|
// Refresh the list.
|
||||||
|
dirContents.clear();
|
||||||
|
storeInfo.clear();
|
||||||
|
chdir(Config::StorePath.c_str());
|
||||||
|
getDirectoryContents(dirContents, {"unistore"});
|
||||||
|
for(uint i=0;i<dirContents.size();i++) {
|
||||||
|
storeInfo.push_back(parseStoreInfo(dirContents[i].name));
|
||||||
|
descript();
|
||||||
|
loadStoreDesc();
|
||||||
|
}
|
||||||
|
mode = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hDown & KEY_RIGHT || hDown & KEY_R) {
|
||||||
|
if (searchSelection == 0) searchSelection = 1;
|
||||||
|
}
|
||||||
|
if (hDown & KEY_LEFT || hDown & KEY_L) {
|
||||||
|
if (searchSelection == 1) searchSelection = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hDown & KEY_A) {
|
||||||
|
if (searchSelection == 0) {
|
||||||
|
std::string fullURL = Input::getString(Lang::get("ENTER_FULL_URL"));
|
||||||
|
gspWaitForVBlank();
|
||||||
|
std::string FILE = Input::getString(Lang::get("ENTER_FILENAME"));
|
||||||
|
ScriptHelper::downloadFile(fullURL, Config::StorePath + FILE, Lang::get("DOWNLOADING") + FILE);
|
||||||
|
} else if (searchSelection == 1) {
|
||||||
|
std::string URL = "https://github.com/";
|
||||||
|
URL += Input::getString(Lang::get("ENTER_OWNER_AND_REPO"));
|
||||||
|
gspWaitForVBlank();
|
||||||
|
std::string FILENAME = Input::getString(Lang::get("ENTER_FILENAME"));
|
||||||
|
URL += "/raw/master/unistore/";
|
||||||
|
URL += FILENAME;
|
||||||
|
ScriptHelper::downloadFile(URL, Config::StorePath + FILENAME, Lang::get("DOWNLOADING") + FILENAME);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hDown & KEY_TOUCH && touching(touch, URLBtn[0])) {
|
||||||
|
std::string fullURL = Input::getString(Lang::get("ENTER_FULL_URL"));
|
||||||
|
gspWaitForVBlank();
|
||||||
|
std::string FILE = Input::getString(Lang::get("ENTER_FILENAME"));
|
||||||
|
ScriptHelper::downloadFile(fullURL, Config::StorePath + FILE, Lang::get("DOWNLOADING") + FILE);
|
||||||
|
} else if (hDown & KEY_TOUCH && touching(touch, URLBtn[1])) {
|
||||||
|
std::string URL = "https://github.com/";
|
||||||
|
URL += Input::getString(Lang::get("ENTER_OWNER_AND_REPO"));
|
||||||
|
gspWaitForVBlank();
|
||||||
|
std::string FILENAME = Input::getString(Lang::get("ENTER_FILENAME"));
|
||||||
|
URL += "/raw/master/unistore/";
|
||||||
|
URL += FILENAME;
|
||||||
|
ScriptHelper::downloadFile(URL, Config::StorePath + FILENAME, Lang::get("DOWNLOADING") + FILENAME);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -47,6 +47,7 @@ std::string Config::ScriptPath;
|
|||||||
std::string Config::MusicPath;
|
std::string Config::MusicPath;
|
||||||
bool Config::Logging;
|
bool Config::Logging;
|
||||||
bool Config::UseBars;
|
bool Config::UseBars;
|
||||||
|
std::string Config::StorePath;
|
||||||
nlohmann::json configJson;
|
nlohmann::json configJson;
|
||||||
|
|
||||||
void Config::load() {
|
void Config::load() {
|
||||||
@@ -138,6 +139,12 @@ void Config::load() {
|
|||||||
Config::UseBars = getBool("BARS");
|
Config::UseBars = getBool("BARS");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(!configJson.contains("STOREPATH")) {
|
||||||
|
Config::StorePath = STORE_PATH;
|
||||||
|
} else {
|
||||||
|
Config::StorePath = getString("STOREPATH");
|
||||||
|
}
|
||||||
|
|
||||||
fclose(file);
|
fclose(file);
|
||||||
} else {
|
} else {
|
||||||
Config::Color1 = BarColor;
|
Config::Color1 = BarColor;
|
||||||
@@ -154,6 +161,7 @@ void Config::load() {
|
|||||||
Config::MusicPath = MUSIC_PATH;
|
Config::MusicPath = MUSIC_PATH;
|
||||||
Config::Logging = false;
|
Config::Logging = false;
|
||||||
Config::UseBars = true;
|
Config::UseBars = true;
|
||||||
|
Config::StorePath = STORE_PATH;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -172,6 +180,7 @@ void Config::save() {
|
|||||||
Config::setString("MUSICPATH", Config::MusicPath);
|
Config::setString("MUSICPATH", Config::MusicPath);
|
||||||
Config::setBool("LOGGING", Config::Logging);
|
Config::setBool("LOGGING", Config::Logging);
|
||||||
Config::setBool("BARS", Config::UseBars);
|
Config::setBool("BARS", Config::UseBars);
|
||||||
|
Config::setString("STOREPATH", Config::StorePath);
|
||||||
FILE* file = fopen("sdmc:/3ds/Universal-Updater/Settings.json", "w");
|
FILE* file = fopen("sdmc:/3ds/Universal-Updater/Settings.json", "w");
|
||||||
if(file) fwrite(configJson.dump(1, '\t').c_str(), 1, configJson.dump(1, '\t').size(), file);
|
if(file) fwrite(configJson.dump(1, '\t').c_str(), 1, configJson.dump(1, '\t').size(), file);
|
||||||
fclose(file);
|
fclose(file);
|
||||||
@@ -194,6 +203,7 @@ void Config::initializeNewConfig() {
|
|||||||
Config::setString("MUSICPATH", MUSIC_PATH);
|
Config::setString("MUSICPATH", MUSIC_PATH);
|
||||||
Config::setBool("LOGGING", false);
|
Config::setBool("LOGGING", false);
|
||||||
Config::setBool("BARS", true);
|
Config::setBool("BARS", true);
|
||||||
|
Config::setString("STOREPATH", STORE_PATH);
|
||||||
|
|
||||||
if(file) fwrite(configJson.dump(1, '\t').c_str(), 1, configJson.dump(1, '\t').size(), file);
|
if(file) fwrite(configJson.dump(1, '\t').c_str(), 1, configJson.dump(1, '\t').size(), file);
|
||||||
fclose(file);
|
fclose(file);
|
||||||
|
|||||||
+52
-17
@@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
#include "screens/screenCommon.hpp"
|
#include "screens/screenCommon.hpp"
|
||||||
|
|
||||||
|
#include "utils/common.hpp"
|
||||||
#include "utils/config.hpp"
|
#include "utils/config.hpp"
|
||||||
#include "utils/fileBrowse.h"
|
#include "utils/fileBrowse.h"
|
||||||
#include "utils/structs.hpp"
|
#include "utils/structs.hpp"
|
||||||
@@ -36,6 +37,7 @@ std::vector<Structs::ButtonPos> buttonPositions = {
|
|||||||
{80, 220, 50, 15, -1}, // Select.
|
{80, 220, 50, 15, -1}, // Select.
|
||||||
{145, 220, 50, 15, -1}, // Refresh.
|
{145, 220, 50, 15, -1}, // Refresh.
|
||||||
{210, 220, 50, 15, -1}, // Back.
|
{210, 220, 50, 15, -1}, // Back.
|
||||||
|
{0, 0, 25, 25, -1}, // ViewMode Change.
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -198,7 +200,10 @@ std::string selectFilePath(std::string selectText, const std::vector<std::string
|
|||||||
static int keyRepeatDelay = 4;
|
static int keyRepeatDelay = 4;
|
||||||
static bool dirChanged = true;
|
static bool dirChanged = true;
|
||||||
static bool fastMode = false;
|
static bool fastMode = false;
|
||||||
|
uint screenPos = 0;
|
||||||
|
uint screenPosList = 0;
|
||||||
std::vector<DirEntry> dirContents;
|
std::vector<DirEntry> dirContents;
|
||||||
|
std::string dirs;
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
Gui::clearTextBufs();
|
Gui::clearTextBufs();
|
||||||
@@ -215,21 +220,28 @@ std::string selectFilePath(std::string selectText, const std::vector<std::string
|
|||||||
Gui::DrawString((400-(Gui::GetStringWidth(0.60f, path)))/2, 0, 0.60f, Config::TxtColor, path);
|
Gui::DrawString((400-(Gui::GetStringWidth(0.60f, path)))/2, 0, 0.60f, Config::TxtColor, path);
|
||||||
Gui::DrawStringCentered(0, 218, 0.60f, Config::TxtColor, selectText, 400);
|
Gui::DrawStringCentered(0, 218, 0.60f, Config::TxtColor, selectText, 400);
|
||||||
}
|
}
|
||||||
|
Gui::DrawBottom();
|
||||||
std::string dirs;
|
if (Config::viewMode == 0) {
|
||||||
for (uint i=(selectedFile<5) ? 0 : selectedFile-5;i<dirContents.size()&&i<((selectedFile<5) ? 6 : selectedFile+1);i++) {
|
for(int i=0;i<ENTRIES_PER_SCREEN && i<(int)dirContents.size();i++) {
|
||||||
if (i == selectedFile) {
|
dirs = dirContents[screenPos + i].name;
|
||||||
dirs += "> " + dirContents[i].name + "\n\n";
|
if(screenPos + i == selectedFile) {
|
||||||
} else {
|
Gui::Draw_Rect(0, 40+(i*57), 320, 45, C2D_Color32(120, 192, 216, 255));
|
||||||
dirs += dirContents[i].name + "\n\n";
|
} else {
|
||||||
|
Gui::Draw_Rect(0, 40+(i*57), 320, 45, C2D_Color32(77, 118, 132, 255));
|
||||||
|
}
|
||||||
|
Gui::DrawStringCentered(0, 50+(i*57), 0.7f, WHITE, dirs, 320);
|
||||||
|
}
|
||||||
|
} else if (Config::viewMode == 1) {
|
||||||
|
for(int i=0;i<ENTRIES_PER_LIST && i<(int)dirContents.size();i++) {
|
||||||
|
dirs = dirContents[screenPosList + i].name;
|
||||||
|
if(screenPosList + i == selectedFile) {
|
||||||
|
Gui::Draw_Rect(0, (i+1)*27, 320, 25, Config::SelectedColor);
|
||||||
|
} else {
|
||||||
|
Gui::Draw_Rect(0, (i+1)*27, 320, 25, Config::UnselectedColor);
|
||||||
|
}
|
||||||
|
Gui::DrawStringCentered(0, ((i+1)*27)+1, 0.7f, Config::TxtColor, dirs, 320);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (uint i=0;i<((dirContents.size()<6) ? 6-dirContents.size() : 0);i++) {
|
|
||||||
dirs += "\n\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
Gui::DrawString(26, 32, 0.53f, Config::TxtColor, dirs.c_str());
|
|
||||||
Gui::DrawBottom();
|
|
||||||
|
|
||||||
if (Config::UseBars == true) {
|
if (Config::UseBars == true) {
|
||||||
Gui::DrawStringCentered(0, 0, 0.5f, Config::TxtColor, Lang::get("FILEBROWSE_MSG"), 320);
|
Gui::DrawStringCentered(0, 0, 0.5f, Config::TxtColor, Lang::get("FILEBROWSE_MSG"), 320);
|
||||||
@@ -238,6 +250,7 @@ std::string selectFilePath(std::string selectText, const std::vector<std::string
|
|||||||
}
|
}
|
||||||
Gui::DrawArrow(295, -1);
|
Gui::DrawArrow(295, -1);
|
||||||
Gui::DrawArrow(315, 240, 180.0);
|
Gui::DrawArrow(315, 240, 180.0);
|
||||||
|
Gui::spriteBlend(sprites_view_idx, buttonPositions[6].x, buttonPositions[6].y);
|
||||||
|
|
||||||
Gui::Draw_Rect(buttonPositions[2].x, buttonPositions[2].y, buttonPositions[2].w, buttonPositions[2].h, C2D_Color32(0, 0, 0, 190));
|
Gui::Draw_Rect(buttonPositions[2].x, buttonPositions[2].y, buttonPositions[2].w, buttonPositions[2].h, C2D_Color32(0, 0, 0, 190));
|
||||||
Gui::Draw_Rect(buttonPositions[3].x, buttonPositions[3].y, buttonPositions[3].w, buttonPositions[3].h, C2D_Color32(0, 0, 0, 190));
|
Gui::Draw_Rect(buttonPositions[3].x, buttonPositions[3].y, buttonPositions[3].w, buttonPositions[3].h, C2D_Color32(0, 0, 0, 190));
|
||||||
@@ -267,11 +280,11 @@ std::string selectFilePath(std::string selectText, const std::vector<std::string
|
|||||||
dirChanged = false;
|
dirChanged = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hidKeysDown() & KEY_SELECT || hidKeysDown() & KEY_TOUCH && touching(touch, buttonPositions[4])) {
|
if ((hidKeysDown() & KEY_SELECT) || (hidKeysDown() & KEY_TOUCH && touching(touch, buttonPositions[4]))) {
|
||||||
dirChanged = true;
|
dirChanged = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hidKeysDown() & KEY_A || hidKeysDown() & KEY_TOUCH && touching(touch, buttonPositions[2])) {
|
if ((hidKeysDown() & KEY_A) || (hidKeysDown() & KEY_TOUCH && touching(touch, buttonPositions[2]))) {
|
||||||
if (dirContents.size() != 0) {
|
if (dirContents.size() != 0) {
|
||||||
if (dirContents[selectedFile].isDirectory) {
|
if (dirContents[selectedFile].isDirectory) {
|
||||||
chdir(dirContents[selectedFile].name.c_str());
|
chdir(dirContents[selectedFile].name.c_str());
|
||||||
@@ -310,7 +323,7 @@ std::string selectFilePath(std::string selectText, const std::vector<std::string
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hidKeysDown() & KEY_B || hidKeysDown() & KEY_TOUCH && touching(touch, buttonPositions[5])) {
|
if ((hidKeysDown() & KEY_B) || (hidKeysDown() & KEY_TOUCH && touching(touch, buttonPositions[5]))) {
|
||||||
char path[PATH_MAX];
|
char path[PATH_MAX];
|
||||||
getcwd(path, PATH_MAX);
|
getcwd(path, PATH_MAX);
|
||||||
if(strcmp(path, "sdmc:/") == 0 || strcmp(path, "/") == 0) {
|
if(strcmp(path, "sdmc:/") == 0 || strcmp(path, "/") == 0) {
|
||||||
@@ -322,7 +335,7 @@ std::string selectFilePath(std::string selectText, const std::vector<std::string
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hidKeysDown() & KEY_X || hidKeysDown() & KEY_TOUCH && touching(touch, buttonPositions[3])) {
|
if ((hidKeysDown() & KEY_X) || (hidKeysDown() & KEY_TOUCH && touching(touch, buttonPositions[3]))) {
|
||||||
char path[PATH_MAX];
|
char path[PATH_MAX];
|
||||||
getcwd(path, PATH_MAX);
|
getcwd(path, PATH_MAX);
|
||||||
selectedPath = path;
|
selectedPath = path;
|
||||||
@@ -339,5 +352,27 @@ std::string selectFilePath(std::string selectText, const std::vector<std::string
|
|||||||
if (hidKeysDown() & KEY_L) {
|
if (hidKeysDown() & KEY_L) {
|
||||||
fastMode = false;
|
fastMode = false;
|
||||||
}
|
}
|
||||||
|
// Switch ViewMode.
|
||||||
|
if ((hidKeysDown() & KEY_Y) || (hidKeysDown() & KEY_TOUCH && touching(touch, buttonPositions[6]))) {
|
||||||
|
if (Config::viewMode == 0) {
|
||||||
|
Config::viewMode = 1;
|
||||||
|
} else {
|
||||||
|
Config::viewMode = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Config::viewMode == 0) {
|
||||||
|
if(selectedFile < screenPos) {
|
||||||
|
screenPos = selectedFile;
|
||||||
|
} else if (selectedFile > screenPos + ENTRIES_PER_SCREEN - 1) {
|
||||||
|
screenPos = selectedFile - ENTRIES_PER_SCREEN + 1;
|
||||||
|
}
|
||||||
|
} else if (Config::viewMode == 1) {
|
||||||
|
if(selectedFile < screenPosList) {
|
||||||
|
screenPosList = selectedFile;
|
||||||
|
} else if (selectedFile > screenPosList + ENTRIES_PER_LIST - 1) {
|
||||||
|
screenPosList = selectedFile - ENTRIES_PER_LIST + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -133,7 +133,7 @@ void ScriptHelper::displayTimeMsg(std::string message, int seconds) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ScriptHelper::checkIfValid(std::string scriptFile) {
|
bool ScriptHelper::checkIfValid(std::string scriptFile, int mode) {
|
||||||
FILE* file = fopen(scriptFile.c_str(), "rt");
|
FILE* file = fopen(scriptFile.c_str(), "rt");
|
||||||
if(!file) {
|
if(!file) {
|
||||||
printf("File not found\n");
|
printf("File not found\n");
|
||||||
@@ -142,7 +142,11 @@ bool ScriptHelper::checkIfValid(std::string scriptFile) {
|
|||||||
nlohmann::json json = nlohmann::json::parse(file, nullptr, false);
|
nlohmann::json json = nlohmann::json::parse(file, nullptr, false);
|
||||||
fclose(file);
|
fclose(file);
|
||||||
|
|
||||||
if (!json.contains("info")) return false;
|
if (mode == 0) {
|
||||||
|
if (!json.contains("info")) return false;
|
||||||
|
} else if (mode == 1) {
|
||||||
|
if (!json.contains("storeInfo")) return false;
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user