summaryrefslogtreecommitdiff
path: root/sc/source/ui
diff options
context:
space:
mode:
Diffstat (limited to 'sc/source/ui')
-rw-r--r--sc/source/ui/inc/optsolver.hxx7
-rw-r--r--sc/source/ui/miscdlgs/optsolver.cxx37
2 files changed, 18 insertions, 26 deletions
diff --git a/sc/source/ui/inc/optsolver.hxx b/sc/source/ui/inc/optsolver.hxx
index eae17564ada3..21b2b5c3ba6e 100644
--- a/sc/source/ui/inc/optsolver.hxx
+++ b/sc/source/ui/inc/optsolver.hxx
@@ -199,14 +199,13 @@ private:
DECL_LINK( SelectHdl, ListBox&, void );
};
-class ScSolverProgressDialog : public ModelessDialog
+class ScSolverProgressDialog : public weld::GenericDialogController
{
- VclPtr<FixedText> m_pFtTime;
+ std::unique_ptr<weld::Label> m_xFtTime;
public:
- ScSolverProgressDialog( vcl::Window* pParent );
+ ScSolverProgressDialog(weld::Window* pParent);
virtual ~ScSolverProgressDialog() override;
- virtual void dispose() override;
void HideTimeLimit();
void SetTimeLimit( sal_Int32 nSeconds );
diff --git a/sc/source/ui/miscdlgs/optsolver.cxx b/sc/source/ui/miscdlgs/optsolver.cxx
index 239591ac28ba..4fd377d87b47 100644
--- a/sc/source/ui/miscdlgs/optsolver.cxx
+++ b/sc/source/ui/miscdlgs/optsolver.cxx
@@ -45,35 +45,27 @@
using namespace com::sun::star;
-ScSolverProgressDialog::ScSolverProgressDialog(vcl::Window* pParent)
- : ModelessDialog(pParent, "SolverProgressDialog",
- "modules/scalc/ui/solverprogressdialog.ui")
+ScSolverProgressDialog::ScSolverProgressDialog(weld::Window* pParent)
+ : GenericDialogController(pParent, "modules/scalc/ui/solverprogressdialog.ui",
+ "SolverProgressDialog")
+ , m_xFtTime(m_xBuilder->weld_label("progress"))
{
- get(m_pFtTime, "progress");
}
ScSolverProgressDialog::~ScSolverProgressDialog()
{
- disposeOnce();
-}
-
-void ScSolverProgressDialog::dispose()
-{
- m_pFtTime.clear();
- ModelessDialog::dispose();
}
-
void ScSolverProgressDialog::HideTimeLimit()
{
- m_pFtTime->Hide();
+ m_xFtTime->hide();
}
void ScSolverProgressDialog::SetTimeLimit( sal_Int32 nSeconds )
{
- OUString aOld = m_pFtTime->GetText();
+ OUString aOld = m_xFtTime->get_label();
OUString aNew = aOld.replaceFirst("#", OUString::number(nSeconds));
- m_pFtTime->SetText( aNew );
+ m_xFtTime->set_label(aNew);
}
ScSolverNoSolutionDialog::ScSolverNoSolutionDialog(weld::Window* pParent, const OUString& rErrorText)
@@ -811,15 +803,15 @@ bool ScOptSolverDlg::CallSolver() // return true -> close dialog after cal
{
// show progress dialog
- ScopedVclPtrInstance< ScSolverProgressDialog > aProgress( this );
+ std::shared_ptr<ScSolverProgressDialog> xProgress(new ScSolverProgressDialog(GetFrameWeld()));
sal_Int32 nTimeout = 0;
if ( FindTimeout( nTimeout ) )
- aProgress->SetTimeLimit( nTimeout );
+ xProgress->SetTimeLimit( nTimeout );
else
- aProgress->HideTimeLimit();
- aProgress->Show();
- aProgress->Update();
- aProgress->Flush();
+ xProgress->HideTimeLimit();
+
+ weld::DialogController::runAsync(xProgress, [](sal_Int32 /*nResult*/){});
+
// try to make sure the progress dialog is painted before continuing
Application::Reschedule(true);
@@ -1009,7 +1001,8 @@ bool ScOptSolverDlg::CallSolver() // return true -> close dialog after cal
xSolver->solve();
bool bSuccess = xSolver->getSuccess();
- aProgress->Hide();
+ xProgress->response(RET_CLOSE);
+
bool bClose = false;
bool bRestore = true; // restore old values unless a solution is accepted
if ( bSuccess )