mirror of
https://github.com/RGBCube/serenity
synced 2025-10-24 12:52:07 +00:00

This change allows us to specify where on screen we'd like the Dialog window to be drawn. By default it's set to CenterWithinParent which may fall back to Center if parent window is unset or not visible on screen.
63 lines
1.2 KiB
C++
63 lines
1.2 KiB
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibGUI/Window.h>
|
|
|
|
namespace GUI {
|
|
|
|
class Dialog : public Window {
|
|
C_OBJECT(Dialog)
|
|
public:
|
|
enum ExecResult {
|
|
ExecOK = 0,
|
|
ExecCancel = 1,
|
|
ExecAborted = 2,
|
|
ExecYes = 3,
|
|
ExecNo = 4,
|
|
};
|
|
enum ScreenPosition {
|
|
CenterWithinParent = 0,
|
|
|
|
Center = 1,
|
|
CenterLeft = 2,
|
|
CenterRight = 3,
|
|
|
|
TopLeft = 4,
|
|
TopCenter = 5,
|
|
TopRight = 6,
|
|
|
|
BottomLeft = 7,
|
|
BottomCenter = 8,
|
|
BottomRight = 9,
|
|
};
|
|
|
|
virtual ~Dialog() override;
|
|
|
|
int exec();
|
|
|
|
int result() const { return m_result; }
|
|
void done(int result);
|
|
|
|
virtual void event(Core::Event&) override;
|
|
|
|
virtual void close() override;
|
|
|
|
protected:
|
|
explicit Dialog(Window* parent_window, ScreenPosition screen_position = CenterWithinParent);
|
|
|
|
private:
|
|
OwnPtr<Core::EventLoop> m_event_loop;
|
|
int m_result { ExecAborted };
|
|
int m_screen_position { CenterWithinParent };
|
|
};
|
|
|
|
}
|
|
|
|
template<>
|
|
struct AK::Formatter<GUI::Dialog> : Formatter<Core::Object> {
|
|
};
|