From 1c39db584f9f1877a9fa5ce00e8d19dd997d8078 Mon Sep 17 00:00:00 2001 From: Akshay Deep Date: Mon, 6 Jun 2016 11:20:16 +0530 Subject: tdf#83054 Writer: Add "Go to Page" Entry in Edit Menu Change-Id: I09026910687b019fe33d4016612b8247ff076100 Reviewed-on: https://gerrit.libreoffice.org/25949 Tested-by: Jenkins Reviewed-by: Samuel Mehrbrodt --- sw/Library_sw.mk | 1 + sw/UIConfig_swriter.mk | 1 + sw/inc/cmdid.h | 2 +- sw/inc/gotodlg.hxx | 55 ++++++++++++ sw/sdi/_viewsh.sdi | 2 +- sw/sdi/swriter.sdi | 2 +- sw/source/uibase/uiview/view2.cxx | 18 ++-- sw/source/uibase/utlui/gotodlg.cxx | 116 +++++++++++++++++++++++++ sw/uiconfig/swriter/ui/gotopagedialog.ui | 140 +++++++++++++++++++++++++++++++ 9 files changed, 321 insertions(+), 16 deletions(-) create mode 100644 sw/inc/gotodlg.hxx create mode 100644 sw/source/uibase/utlui/gotodlg.cxx create mode 100644 sw/uiconfig/swriter/ui/gotopagedialog.ui (limited to 'sw') diff --git a/sw/Library_sw.mk b/sw/Library_sw.mk index ea8c36205f48..c563c9c6b816 100644 --- a/sw/Library_sw.mk +++ b/sw/Library_sw.mk @@ -734,6 +734,7 @@ $(eval $(call gb_Library_add_exception_objects,sw,\ sw/source/uibase/utlui/initui \ sw/source/uibase/utlui/navicfg \ sw/source/uibase/utlui/navipi \ + sw/source/uibase/utlui/gotodlg \ sw/source/uibase/utlui/numfmtlb \ sw/source/uibase/utlui/prcntfld \ sw/source/uibase/utlui/shdwcrsr \ diff --git a/sw/UIConfig_swriter.mk b/sw/UIConfig_swriter.mk index da0fc29950df..174575ba55af 100644 --- a/sw/UIConfig_swriter.mk +++ b/sw/UIConfig_swriter.mk @@ -145,6 +145,7 @@ $(eval $(call gb_UIConfig_add_uifiles,modules/swriter,\ sw/uiconfig/swriter/ui/frmaddpage \ sw/uiconfig/swriter/ui/frmtypepage \ sw/uiconfig/swriter/ui/frmurlpage \ + sw/uiconfig/swriter/ui/gotopagedialog \ sw/uiconfig/swriter/ui/indexentry \ sw/uiconfig/swriter/ui/inputfielddialog \ sw/uiconfig/swriter/ui/indentpage \ diff --git a/sw/inc/cmdid.h b/sw/inc/cmdid.h index a832571b993c..7223028fc858 100644 --- a/sw/inc/cmdid.h +++ b/sw/inc/cmdid.h @@ -505,7 +505,7 @@ #define FN_UPDATE_CUR_TOX (FN_EXTRA + 54) /* update current index */ #define FN_REMOVE_CUR_TOX (FN_EXTRA + 55) /* remove the current TOX*/ -#define FN_NAVIGATION_PI_GOTO_PAGE (FN_EXTRA + 59 ) /* goto page from navigation-PI */ +#define FN_GOTO_PAGE (FN_EXTRA + 59 ) /* goto page */ #define FN_COLL_TYPE (FN_EXTRA + 98) /* type for GlobalDoc-Collection*/ #define FN_COLL_ADD (FN_EXTRA + 99) diff --git a/sw/inc/gotodlg.hxx b/sw/inc/gotodlg.hxx new file mode 100644 index 000000000000..b1d531a1a6d5 --- /dev/null +++ b/sw/inc/gotodlg.hxx @@ -0,0 +1,55 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * This file is part of the LibreOffice project. + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + * + * This file incorporates work covered by the following license notice: + * + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed + * with this work for additional information regarding copyright + * ownership. The ASF licenses this file to you under the Apache + * License, Version 2.0 (the "License"); you may not use this file + * except in compliance with the License. You may obtain a copy of + * the License at http://www.apache.org/licenses/LICENSE-2.0 . + */ + +#ifndef INCLUDED_SW_SOURCE_UIBASE_INC_GOTODLG_HXX +#define INCLUDED_SW_SOURCE_UIBASE_INC_GOTODLG_HXX + +#include + +class SwView; +class SwWrtShell; + +class SwGotoPageDlg : public ModalDialog +{ +public: + SwGotoPageDlg(vcl::Window *parent = nullptr, SfxBindings* _pBindings = nullptr); + + virtual ~SwGotoPageDlg(); + virtual void dispose() override; + + sal_uInt16 GetPageSelection() const{ + return (mpMtrPageCtrl->GetText()).toUInt32();} + +private: + SwView* GetCreateView() const; + sal_uInt16 GetPageInfo(); + + DECL_LINK_TYPED( PageModifiedHdl, Edit&, void ); + + VclPtr mpMtrPageCtrl; + VclPtr mpPageNumberLbl; + + SwView *m_pCreateView; + SfxBindings *m_rBindings; + sal_uInt16 mnMaxPageCnt; +}; + +#endif + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ \ No newline at end of file diff --git a/sw/sdi/_viewsh.sdi b/sw/sdi/_viewsh.sdi index 065f072bf69f..27779439a342 100644 --- a/sw/sdi/_viewsh.sdi +++ b/sw/sdi/_viewsh.sdi @@ -62,7 +62,7 @@ interface BaseTextEditView ExecMethod = Execute ; StateMethod = GetState ; ] - FN_NAVIGATION_PI_GOTO_PAGE // status(final|play) + FN_GOTO_PAGE // status(final|play) [ ExecMethod = Execute ; StateMethod = NoState ; diff --git a/sw/sdi/swriter.sdi b/sw/sdi/swriter.sdi index d4246d6be4ed..6c7aa8812ace 100644 --- a/sw/sdi/swriter.sdi +++ b/sw/sdi/swriter.sdi @@ -1840,7 +1840,7 @@ SfxBoolItem GotoNextWrongTableFormula FN_NEXT_TBLFML_ERR GroupId = GID_NAVIGATOR; ] -SfxVoidItem GotoPage FN_NAVIGATION_PI_GOTO_PAGE +SfxVoidItem GotoPage FN_GOTO_PAGE () [ AutoUpdate = FALSE, diff --git a/sw/source/uibase/uiview/view2.cxx b/sw/source/uibase/uiview/view2.cxx index 67911a5ee199..c08525a0f2d2 100644 --- a/sw/source/uibase/uiview/view2.cxx +++ b/sw/source/uibase/uiview/view2.cxx @@ -76,6 +76,7 @@ #include #include #include +#include #include #include #include @@ -880,20 +881,11 @@ void SwView::Execute(SfxRequest &rReq) } } break; - case FN_NAVIGATION_PI_GOTO_PAGE: + case FN_GOTO_PAGE: { - SfxViewFrame* pVFrame = GetViewFrame(); - SfxChildWindow* pCh = pVFrame->GetChildWindow( SID_NAVIGATOR ); - if(!pCh) - { - pVFrame->ToggleChildWindow( SID_NAVIGATOR ); - pCh = pVFrame->GetChildWindow( SID_NAVIGATOR ); - - } - if (pCh) - { - static_cast( pCh->GetContextWindow(SW_MOD()))->GotoPage(); - } + ScopedVclPtrInstance< SwGotoPageDlg > aDlg (&GetViewFrame()->GetWindow(), &GetViewFrame()->GetBindings()); + if(aDlg->Execute() == RET_OK) + GetWrtShell().GotoPage((sal_uInt16)aDlg->GetPageSelection(), true); } break; case FN_EDIT_CURRENT_TOX: diff --git a/sw/source/uibase/utlui/gotodlg.cxx b/sw/source/uibase/utlui/gotodlg.cxx new file mode 100644 index 000000000000..107d62a27daa --- /dev/null +++ b/sw/source/uibase/utlui/gotodlg.cxx @@ -0,0 +1,116 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * This file is part of the LibreOffice project. + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + * + * This file incorporates work covered by the following license notice: + * + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed + * with this work for additional information regarding copyright + * ownership. The ASF licenses this file to you under the Apache + * License, Version 2.0 (the "License"); you may not use this file + * except in compliance with the License. You may obtain a copy of + * the License at http://www.apache.org/licenses/LICENSE-2.0 . + */ + +#include +#include +#include +#include +#include +#include +#include + +using namespace com::sun::star; + +SwGotoPageDlg::SwGotoPageDlg( vcl::Window* pParent, SfxBindings* _pBindings): + ModalDialog(pParent, "GotoPageDialog", "modules/swriter/ui/gotopagedialog.ui"), + m_pCreateView(nullptr), + m_rBindings(_pBindings), + mnMaxPageCnt(1) +{ + get(mpMtrPageCtrl, "page"); + get(mpPageNumberLbl, "page_count"); + + sal_uInt16 nTotalPage = GetPageInfo(); + + if(nTotalPage) + { + OUString sStr = mpPageNumberLbl->GetText(); + mpPageNumberLbl->SetText(sStr.replaceFirst("$1", OUString::number(nTotalPage))); + mnMaxPageCnt = nTotalPage; + } + mpMtrPageCtrl->SetModifyHdl(LINK(this, SwGotoPageDlg, PageModifiedHdl)); + mpMtrPageCtrl->SetCursorAtLast(); +} + +SwGotoPageDlg::~SwGotoPageDlg() +{ + disposeOnce(); +} + +void SwGotoPageDlg::dispose() +{ + mpMtrPageCtrl.clear(); + mpPageNumberLbl.clear(); + + ModalDialog::dispose(); +} + +IMPL_LINK_NOARG_TYPED(SwGotoPageDlg, PageModifiedHdl, Edit&, void) +{ + if(!(mpMtrPageCtrl->GetText()).isEmpty() ) + { + int page_value = (mpMtrPageCtrl->GetText()).toInt32(); + + if(page_value <= 0.0) + mpMtrPageCtrl->SetText(OUString::number(1)); + else if(page_value > mnMaxPageCnt) + mpMtrPageCtrl->SetText(OUString::number(mnMaxPageCnt)); + + mpMtrPageCtrl->SetCursorAtLast(); + } +} + +SwView* SwGotoPageDlg::GetCreateView() const +{ + if(!m_pCreateView) + { + SwView* pView = SwModule::GetFirstView(); + while(pView) + { + if(&pView->GetViewFrame()->GetBindings() == m_rBindings) + { + const_cast(this)->m_pCreateView = pView; + break; + } + pView = SwModule::GetNextView(pView); + } + } + + return m_pCreateView; +} + +// If the page can be set here, the maximum is set. + +sal_uInt16 SwGotoPageDlg::GetPageInfo() +{ + SwView *pView = GetCreateView(); + SwWrtShell *pSh = pView ? &pView->GetWrtShell() : nullptr; + mpMtrPageCtrl->SetText(OUString::number(1)); + if (pSh) + { + const sal_uInt16 nPageCnt = pSh->GetPageCnt(); + sal_uInt16 nPhyPage, nVirPage; + pSh->GetPageNum(nPhyPage, nVirPage); + mpMtrPageCtrl->SetText(OUString::number(nPhyPage)); + return nPageCnt; + } + return 0; +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ \ No newline at end of file diff --git a/sw/uiconfig/swriter/ui/gotopagedialog.ui b/sw/uiconfig/swriter/ui/gotopagedialog.ui new file mode 100644 index 000000000000..345d308e5664 --- /dev/null +++ b/sw/uiconfig/swriter/ui/gotopagedialog.ui @@ -0,0 +1,140 @@ + + + + + + False + 6 + Go to Page + dialog + + + False + vertical + 12 + + + False + end + + + gtk-help + True + True + True + True + + + False + True + 0 + True + + + + + gtk-ok + True + True + True + True + False + True + + + False + True + 1 + + + + + gtk-cancel + True + True + True + True + + + False + True + 2 + + + + + False + True + end + 0 + + + + + True + False + 6 + 12 + 12 + + + True + False + True + 0 + of $1 + True + + + 2 + 0 + + + + + True + True + number + + + 1 + 0 + + + + + True + False + True + 0 + Page: + True + + + 0 + 0 + + + + + True + True + 1 + + + + + + button1 + ok + cancel + + + + 1 + 75 + 1 + 1 + 10 + + -- cgit