diff options
author | Kae <80987908+Novaenia@users.noreply.github.com> | 2023-06-20 14:33:09 +1000 |
---|---|---|
committer | Kae <80987908+Novaenia@users.noreply.github.com> | 2023-06-20 14:33:09 +1000 |
commit | 6352e8e3196f78388b6c771073f9e03eaa612673 (patch) | |
tree | e23772f79a7fbc41bc9108951e9e136857484bf4 /source/frontend/StarPopupInterface.cpp | |
parent | 6741a057e5639280d85d0f88ba26f000baa58f61 (diff) |
everything everywhere
all at once
Diffstat (limited to 'source/frontend/StarPopupInterface.cpp')
-rw-r--r-- | source/frontend/StarPopupInterface.cpp | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/source/frontend/StarPopupInterface.cpp b/source/frontend/StarPopupInterface.cpp new file mode 100644 index 0000000..65b1f54 --- /dev/null +++ b/source/frontend/StarPopupInterface.cpp @@ -0,0 +1,30 @@ +#include "StarPopupInterface.hpp" +#include "StarGuiReader.hpp" +#include "StarRoot.hpp" +#include "StarLabelWidget.hpp" +#include "StarRandom.hpp" +#include "StarAssets.hpp" + +namespace Star { + +PopupInterface::PopupInterface() { + auto assets = Root::singleton().assets(); + + GuiReader reader; + + reader.registerCallback("close", [=](Widget*) { dismiss(); }); + reader.registerCallback("ok", [=](Widget*) { dismiss(); }); + + reader.construct(assets->json("/interface/windowconfig/popup.config:paneLayout"), this); +} + +void PopupInterface::displayMessage(String const& message, String const& title, String const& subtitle, Maybe<String> const& onShowSound) { + setTitleString(title, subtitle); + fetchChild<LabelWidget>("message")->setText(message); + show(); + auto sound = onShowSound.value(Random::randValueFrom(Root::singleton().assets()->json("/interface/windowconfig/popup.config:onShowSound").toArray(), "").toString()); + if (!sound.empty()) + context()->playAudio(sound); +} + +} |