diff --git a/include/about_tab.hpp b/include/about_tab.hpp index deee0f6..f9aaf7f 100644 --- a/include/about_tab.hpp +++ b/include/about_tab.hpp @@ -36,7 +36,7 @@ namespace nxdt::views void onFocusGained(void) override; public: - AboutTabLabel(brls::LabelStyle labelStyle, std::string text, bool center = false, bool multiline = true); + AboutTabLabel(brls::LabelStyle labelStyle, std::string text, bool center = false); }; class AboutTab: public brls::List diff --git a/romfs/i18n/en-US/about_tab.json b/romfs/i18n/en-US/about_tab.json index 42230e2..ea3cd41 100644 --- a/romfs/i18n/en-US/about_tab.json +++ b/romfs/i18n/en-US/about_tab.json @@ -4,17 +4,31 @@ "copyright": "Licensed under GPLv3+\n\u00A9 2020 - 2021 {0}\n{1}", "dependencies": { - "header": "Dependencies", - "value": "\uE016 {0} is powered by Borealis, a hardware-accelerated UI library: {1}.\n\uE016 USB Mass Storage device support is powered by libusbhsfs: {2}.\n\uE016 FatFs is used to mount FAT volumes from the eMMC storage: {3}.\n\uE016 LZ4 is used to decompress NSO binaries: {4}." + "header": "Dependencies", + "line_00": "\uE016 {0} is powered by Borealis, a hardware-accelerated UI library: {1}.", + "line_01": "\uE016 USB Mass Storage device support is powered by libusbhsfs: {0}.", + "line_02": "\uE016 FatFs is used to mount FAT volumes from the eMMC storage: {0}.", + "line_03": "\uE016 LZ4 is used to decompress NSO binaries: {0}." }, "acknowledgments": { - "header": "Acknowledgments", - "value": "\uE016 Switchbrew and libnx contributors.\n\uE016 SciresM, for hactool and Atmosphère-NX.\n\uE016 shchmue, for Lockpick and its runtime key-collection algorithm, as well as helping in reverse engineering tasks.\n\uE016 Adubbz, for Tinfoil and its ES service bindings.\n\uE016 RattletraPM, for the awesome icon.\n\uE016 Whovian9369, for being a key piece throughout the whole development by providing with lots of testing and cool ideas.\n\uE016 0Liam and Shadów, for their tremendous help in understanding Nintendo Switch file and data formats.\n\uE016 The folks from NSWDB.COM and No-Intro.org, for being kind enough to put up public APIs to perform online checksum lookups.\n\uE016 The folks at the nxdumptool Discord server.\n\uE016 The Comfy Boyes, for always being awesome and supportive. You know who you are.\n\uE016 My girlfriend, for always being by my side and motivating me to keep working on all my projects. I love you. \u2665\n\uE016 And, at last but not least, you! Thank you for using my work!" + "header": "Acknowledgments", + "line_00": "\uE016 Switchbrew and libnx contributors.", + "line_01": "\uE016 SciresM, for hactool and Atmosphère-NX.", + "line_02": "\uE016 shchmue, for Lockpick and its runtime key-collection algorithm, as well as helping in reverse engineering tasks.", + "line_03": "\uE016 Adubbz, for Tinfoil and its ES service bindings.", + "line_04": "\uE016 RattletraPM, for the awesome icon.", + "line_05": "\uE016 Whovian9369, for being a key piece throughout the whole development by providing with lots of testing and cool ideas.", + "line_06": "\uE016 0Liam, Shadów and SimonTime, for their tremendous help in understanding Nintendo Switch file and data formats.", + "line_07": "\uE016 The folks from NSWDB.COM and No-Intro.org, for being kind enough to put up public APIs to perform online checksum lookups.", + "line_08": "\uE016 The folks at the nxdumptool Discord server.", + "line_09": "\uE016 The Comfy Boyes, for always being awesome and supportive. You know who you are.", + "line_10": "\uE016 My girlfriend, for always being by my side and motivating me to keep working on all my projects. I love you. \u2665", + "line_11": "\uE016 And, at last but not least, you! Thank you for using my work!" }, "links": { - "header": "Additional links and resources", - "value": "\uE016 Discord server: {0}." + "header": "Additional links and resources", + "line_00": "\uE016 Discord server: {0}." } } diff --git a/source/about_tab.cpp b/source/about_tab.cpp index 4728738..ea3e774 100644 --- a/source/about_tab.cpp +++ b/source/about_tab.cpp @@ -29,7 +29,7 @@ using namespace i18n::literals; /* For _i18n. */ namespace nxdt::views { - AboutTabLabel::AboutTabLabel(brls::LabelStyle labelStyle, std::string text, bool center, bool multiline) : brls::Label(labelStyle, text, multiline) + AboutTabLabel::AboutTabLabel(brls::LabelStyle labelStyle, std::string text, bool center) : brls::Label(labelStyle, text, true) { if (center) this->setHorizontalAlign(NVG_ALIGN_CENTER); } @@ -48,6 +48,7 @@ namespace nxdt::views AboutTab::AboutTab(void) : brls::List() { + /* Set custom spacing. */ this->setSpacing(this->getSpacing() / 2); this->setMarginBottom(20); @@ -59,28 +60,28 @@ namespace nxdt::views this->logo->setOpacity(0.3F); /* Description. */ - AboutTabLabel* description = new AboutTabLabel(brls::LabelStyle::CRASH, "about_tab/description"_i18n, true); - this->addView(description); + this->addView(new AboutTabLabel(brls::LabelStyle::CRASH, "about_tab/description"_i18n, true)); /* Copyright. */ - brls::Label* copyright = new brls::Label(brls::LabelStyle::DESCRIPTION, i18n::getStr("about_tab/copyright"_i18n, APP_AUTHOR, GITHUB_REPOSITORY_URL), true); + brls::Label *copyright = new brls::Label(brls::LabelStyle::DESCRIPTION, i18n::getStr("about_tab/copyright"_i18n, APP_AUTHOR, GITHUB_REPOSITORY_URL), true); copyright->setHorizontalAlign(NVG_ALIGN_CENTER); this->addView(copyright); /* Dependencies. */ this->addView(new brls::Header("about_tab/dependencies/header"_i18n)); - brls::Label* dependencies = new brls::Label(brls::LabelStyle::SMALL, i18n::getStr("about_tab/dependencies/value"_i18n, APP_TITLE, BOREALIS_URL, LIBUSBHSFS_URL, FATFS_URL, LZ4_URL), true); - this->addView(dependencies); + this->addView(new brls::Label(brls::LabelStyle::SMALL, i18n::getStr("about_tab/dependencies/line_00"_i18n, APP_TITLE, BOREALIS_URL), true)); + this->addView(new AboutTabLabel(brls::LabelStyle::SMALL, i18n::getStr("about_tab/dependencies/line_01"_i18n, LIBUSBHSFS_URL))); + this->addView(new AboutTabLabel(brls::LabelStyle::SMALL, i18n::getStr("about_tab/dependencies/line_02"_i18n, FATFS_URL))); + this->addView(new AboutTabLabel(brls::LabelStyle::SMALL, i18n::getStr("about_tab/dependencies/line_03"_i18n, LZ4_URL))); /* Acknowledgments. */ this->addView(new brls::Header("about_tab/acknowledgments/header"_i18n)); - AboutTabLabel* acknowledgments = new AboutTabLabel(brls::LabelStyle::SMALL, "about_tab/acknowledgments/value"_i18n); - this->addView(acknowledgments); + for(int i = 0; i < 8; i++) this->addView(new AboutTabLabel(brls::LabelStyle::SMALL, i18n::getStr(fmt::format("about_tab/acknowledgments/line_{:02d}", i)), false)); + for(int i = 8; i < 12; i++) this->addView(new brls::Label(brls::LabelStyle::SMALL, i18n::getStr(fmt::format("about_tab/acknowledgments/line_{:02d}", i)), true)); /* Additional links and resources. */ this->addView(new brls::Header("about_tab/links/header"_i18n)); - AboutTabLabel* links = new AboutTabLabel(brls::LabelStyle::SMALL, i18n::getStr("about_tab/links/value"_i18n, DISCORD_SERVER_URL)); - this->addView(links); + this->addView(new AboutTabLabel(brls::LabelStyle::SMALL, i18n::getStr("about_tab/links/line_00"_i18n, DISCORD_SERVER_URL))); } AboutTab::~AboutTab(void)