2020-09-20 01:21:28 +01:00
|
|
|
#include "confirm_page.hpp"
|
2021-02-10 16:28:47 +00:00
|
|
|
#include "utils.hpp"
|
|
|
|
#include "main_frame.hpp"
|
2021-05-21 17:12:58 +01:00
|
|
|
#include "fs.hpp"
|
2021-05-28 14:51:30 +01:00
|
|
|
#include "utils.hpp"
|
2021-02-10 16:28:47 +00:00
|
|
|
#include <algorithm>
|
2021-05-21 17:12:58 +01:00
|
|
|
#include <filesystem>
|
|
|
|
#include <string>
|
|
|
|
|
2020-10-05 23:53:12 +01:00
|
|
|
namespace i18n = brls::i18n;
|
|
|
|
using namespace i18n::literals;
|
2021-05-21 17:12:58 +01:00
|
|
|
ConfirmPage::ConfirmPage(brls::StagedAppletFrame* frame, std::string text, bool done, bool reboot, bool erista): done(done), reboot(reboot), erista(erista)
|
2020-09-20 01:21:28 +01:00
|
|
|
{
|
2021-03-10 20:54:17 +00:00
|
|
|
this->button = (new brls::Button(brls::ButtonStyle::REGULAR))->setLabel(done ? "menus/common/back"_i18n : "menus/common/continue"_i18n);
|
2020-09-20 01:21:28 +01:00
|
|
|
this->button->setParent(this);
|
|
|
|
this->button->getClickEvent()->subscribe([frame, this](View* view) {
|
2020-12-12 15:41:56 +00:00
|
|
|
if (!frame->isLastStage()) {
|
|
|
|
frame->nextStage();
|
|
|
|
}
|
2020-09-20 01:21:28 +01:00
|
|
|
else if (this->done) {
|
|
|
|
brls::Application::pushView(new MainFrame());
|
|
|
|
}
|
2021-05-21 17:12:58 +01:00
|
|
|
else if (this->reboot) {
|
2021-05-24 18:23:16 +01:00
|
|
|
if(this->erista) {
|
2021-05-28 14:51:30 +01:00
|
|
|
util::rebootToPayload(RCM_PAYLOAD_PATH);
|
2021-05-24 18:23:16 +01:00
|
|
|
}
|
2021-05-21 17:12:58 +01:00
|
|
|
else {
|
|
|
|
if(std::filesystem::exists(UPDATE_BIN_PATH)) {
|
|
|
|
fs::copyFile(UPDATE_BIN_PATH, MARIKO_PAYLOAD_PATH_TEMP);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
fs::copyFile(REBOOT_PAYLOAD_PATH, MARIKO_PAYLOAD_PATH_TEMP);
|
|
|
|
}
|
|
|
|
fs::copyFile(RCM_PAYLOAD_PATH, MARIKO_PAYLOAD_PATH);
|
|
|
|
util::shutDown(true);
|
|
|
|
}
|
2020-12-12 15:41:56 +00:00
|
|
|
}
|
2020-09-20 01:21:28 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
this->label = new brls::Label(brls::LabelStyle::DIALOG, text, true);
|
|
|
|
this->label->setHorizontalAlign(NVG_ALIGN_CENTER);
|
|
|
|
this->label->setParent(this);
|
|
|
|
|
2021-02-27 16:11:56 +00:00
|
|
|
if(this->done)
|
|
|
|
this->registerAction("", brls::Key::B, [this] { return true; });
|
2020-09-20 01:21:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void ConfirmPage::draw(NVGcontext* vg, int x, int y, unsigned width, unsigned height, brls::Style* style, brls::FrameContext* ctx)
|
|
|
|
{
|
|
|
|
if(!this->done){
|
|
|
|
auto end = std::chrono::high_resolution_clock::now();
|
2020-09-20 21:58:40 +01:00
|
|
|
auto missing = std::max(1l - std::chrono::duration_cast<std::chrono::seconds>(end - start).count(), 0l);
|
2021-03-10 20:54:17 +00:00
|
|
|
auto text = std::string("menus/common/continue"_i18n);
|
2020-09-20 01:21:28 +01:00
|
|
|
if (missing > 0) {
|
|
|
|
this->button->setLabel(text + " (" + std::to_string(missing) + ")");
|
|
|
|
this->button->setState(brls::ButtonState::DISABLED);
|
|
|
|
} else {
|
|
|
|
this->button->setLabel(text);
|
|
|
|
this->button->setState(brls::ButtonState::ENABLED);
|
|
|
|
}
|
|
|
|
this->button->invalidate();
|
|
|
|
}
|
2020-09-20 21:58:40 +01:00
|
|
|
else{
|
|
|
|
this->button->setState(brls::ButtonState::ENABLED);
|
|
|
|
}
|
2020-09-20 01:21:28 +01:00
|
|
|
this->label->frame(ctx);
|
|
|
|
this->button->frame(ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
brls::View* ConfirmPage::getDefaultFocus()
|
|
|
|
{
|
|
|
|
return this->button;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ConfirmPage::layout(NVGcontext* vg, brls::Style* style, brls::FontStash* stash)
|
|
|
|
{
|
|
|
|
this->label->setWidth(this->width);
|
|
|
|
this->label->invalidate(true);
|
|
|
|
// this->label->setBackground(brls::ViewBackground::DEBUG);
|
|
|
|
this->label->setBoundaries(
|
|
|
|
this->x + this->width / 2 - this->label->getWidth() / 2,
|
|
|
|
this->y + (this->height - this->label->getHeight() - this->y - style->CrashFrame.buttonHeight)/2,
|
|
|
|
this->label->getWidth(),
|
|
|
|
this->label->getHeight());
|
|
|
|
|
|
|
|
this->button->setBoundaries(
|
|
|
|
this->x + this->width / 2 - style->CrashFrame.buttonWidth / 2,
|
|
|
|
this->y + (this->height-style->CrashFrame.buttonHeight*3),
|
|
|
|
style->CrashFrame.buttonWidth,
|
|
|
|
style->CrashFrame.buttonHeight);
|
|
|
|
this->button->invalidate();
|
|
|
|
|
|
|
|
start = std::chrono::high_resolution_clock::now() + std::chrono::milliseconds(150);
|
|
|
|
}
|
|
|
|
|
|
|
|
ConfirmPage::~ConfirmPage()
|
|
|
|
{
|
|
|
|
delete this->label;
|
|
|
|
delete this->button;
|
|
|
|
}
|