lokdialog: convert the show sheet dialog to async exec

Change-Id: I501d9444ef9798a26b4db06ab51e4fb691144b17
Reviewed-on: https://gerrit.libreoffice.org/51094
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Henry Castro <hcastro@collabora.com>
This commit is contained in:
Henry Castro
2018-03-11 18:44:58 -04:00
parent cab04bc39b
commit c9c0f257f4

View File

@@ -135,7 +135,7 @@ void ScTabViewShell::ExecuteTable( SfxRequest& rReq )
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create(); ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
OSL_ENSURE(pFact, "ScAbstractFactory create fail!"); OSL_ENSURE(pFact, "ScAbstractFactory create fail!");
ScopedVclPtr<AbstractScShowTabDlg> pDlg(pFact->CreateScShowTabDlg(GetDialogParent())); VclPtr<AbstractScShowTabDlg> pDlg(pFact->CreateScShowTabDlg(GetDialogParent()));
OSL_ENSURE(pDlg, "Dialog create fail!"); OSL_ENSURE(pDlg, "Dialog create fail!");
OUString aTabName; OUString aTabName;
@@ -150,18 +150,24 @@ void ScTabViewShell::ExecuteTable( SfxRequest& rReq )
} }
} }
if ( pDlg->Execute() == RET_OK ) std::shared_ptr<SfxRequest> pReq = std::make_shared<SfxRequest>(rReq);
pDlg->StartExecuteAsync([this, pDlg, pReq](sal_Int32 nResult){
OUString sTable;
std::vector<OUString> sTables;
if (RET_OK == nResult)
{ {
const sal_Int32 nCount = pDlg->GetSelectedEntryCount(); const sal_Int32 nCount = pDlg->GetSelectedEntryCount();
for (sal_Int32 nPos=0; nPos<nCount; ++nPos) for (sal_Int32 nPos=0; nPos<nCount; ++nPos)
{ {
aName = pDlg->GetSelectedEntry(nPos); sTable = pDlg->GetSelectedEntry(nPos);
rReq.AppendItem( SfxStringItem( FID_TABLE_SHOW, aName ) ); pReq->AppendItem( SfxStringItem( FID_TABLE_SHOW, sTable ) );
rNames.push_back(aName); sTables.push_back(sTable);
} }
ShowTable( rNames ); ShowTable( sTables );
rReq.Done(); pReq->Done();
} }
});
rReq.Ignore();
} }
} }
break; break;