diff options
Diffstat (limited to '')
-rw-r--r-- | sc/source/ui/optdlg/tpdefaults.cxx | 134 |
1 files changed, 134 insertions, 0 deletions
diff --git a/sc/source/ui/optdlg/tpdefaults.cxx b/sc/source/ui/optdlg/tpdefaults.cxx new file mode 100644 index 000000000..7a47f3dbc --- /dev/null +++ b/sc/source/ui/optdlg/tpdefaults.cxx @@ -0,0 +1,134 @@ +/* -*- 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/. + */ + +#undef SC_DLLIMPLEMENTATION + +#include <tpdefaults.hxx> +#include <sc.hrc> +#include <defaultsoptions.hxx> +#include <document.hxx> +#include <officecfg/Office/Common.hxx> +#include <config_features.h> + +ScTpDefaultsOptions::ScTpDefaultsOptions(weld::Container* pPage, weld::DialogController* pController, const SfxItemSet &rCoreSet) + : SfxTabPage(pPage, pController, "modules/scalc/ui/optdefaultpage.ui", "OptDefaultPage", &rCoreSet) + , m_xEdNSheets(m_xBuilder->weld_spin_button("sheetsnumber")) + , m_xEdSheetPrefix(m_xBuilder->weld_entry("sheetprefix")) + , m_xEdJumboSheets(m_xBuilder->weld_check_button("jumbo_sheets")) +{ + m_xEdNSheets->connect_changed( LINK(this, ScTpDefaultsOptions, NumModifiedHdl) ); + m_xEdSheetPrefix->connect_changed( LINK(this, ScTpDefaultsOptions, PrefixModifiedHdl) ); + m_xEdSheetPrefix->connect_focus_in( LINK(this, ScTpDefaultsOptions, PrefixEditOnFocusHdl) ); +#if HAVE_FEATURE_JUMBO_SHEETS + if (!officecfg::Office::Common::Misc::ExperimentalMode::get()) +#endif + m_xEdJumboSheets->hide(); +} + +ScTpDefaultsOptions::~ScTpDefaultsOptions() +{ +} + +std::unique_ptr<SfxTabPage> ScTpDefaultsOptions::Create(weld::Container* pPage, weld::DialogController* pController, const SfxItemSet *rCoreAttrs) +{ + return std::make_unique<ScTpDefaultsOptions>(pPage, pController, *rCoreAttrs); +} + +bool ScTpDefaultsOptions::FillItemSet(SfxItemSet *rCoreSet) +{ + bool bRet = false; + ScDefaultsOptions aOpt; + + SCTAB nTabCount = static_cast<SCTAB>(m_xEdNSheets->get_value()); + OUString aSheetPrefix = m_xEdSheetPrefix->get_text(); + bool bJumboSheets = m_xEdJumboSheets->get_state(); + + if ( m_xEdNSheets->get_value_changed_from_saved() + || m_xEdSheetPrefix->get_saved_value() != aSheetPrefix + || m_xEdJumboSheets->get_saved_state() != (bJumboSheets ? TRISTATE_TRUE : TRISTATE_FALSE) ) + { + aOpt.SetInitTabCount( nTabCount ); + aOpt.SetInitTabPrefix( aSheetPrefix ); +#if HAVE_FEATURE_JUMBO_SHEETS + aOpt.SetInitJumboSheets( bJumboSheets ); +#endif + rCoreSet->Put( ScTpDefaultsItem( aOpt ) ); + bRet = true; + } + return bRet; +} + +void ScTpDefaultsOptions::Reset(const SfxItemSet* rCoreSet) +{ + ScDefaultsOptions aOpt; + + if(const ScTpDefaultsItem* pDefaultsItem = rCoreSet->GetItemIfSet(SID_SCDEFAULTSOPTIONS, false)) + aOpt = pDefaultsItem->GetDefaultsOptions(); + + m_xEdNSheets->set_value(aOpt.GetInitTabCount()); + m_xEdSheetPrefix->set_text( aOpt.GetInitTabPrefix() ); + m_xEdJumboSheets->set_state( aOpt.GetInitJumboSheets() ? TRISTATE_TRUE : TRISTATE_FALSE ); + m_xEdNSheets->save_value(); + m_xEdSheetPrefix->save_value(); + m_xEdJumboSheets->save_state(); +} + +DeactivateRC ScTpDefaultsOptions::DeactivatePage(SfxItemSet* /*pSet*/) +{ + return DeactivateRC::KeepPage; +} + +void ScTpDefaultsOptions::CheckNumSheets() +{ + auto nVal = m_xEdNSheets->get_value(); + if (nVal > MAXINITTAB) + m_xEdNSheets->set_value(MAXINITTAB); + if (nVal < MININITTAB) + m_xEdNSheets->set_value(MININITTAB); +} + +void ScTpDefaultsOptions::CheckPrefix() +{ + OUString aSheetPrefix = m_xEdSheetPrefix->get_text(); + + if (!aSheetPrefix.isEmpty() && !ScDocument::ValidTabName(aSheetPrefix)) + { + // Revert to last good Prefix and also select it to + // indicate something illegal was typed + m_xEdSheetPrefix->set_text(maOldPrefixValue); + m_xEdSheetPrefix->select_region(0, -1); + } + else + { + OnFocusPrefixInput(); + } +} + +void ScTpDefaultsOptions::OnFocusPrefixInput() +{ + // Store Prefix in case we need to revert + maOldPrefixValue = m_xEdSheetPrefix->get_text(); +} + +IMPL_LINK_NOARG(ScTpDefaultsOptions, NumModifiedHdl, weld::Entry&, void) +{ + CheckNumSheets(); +} + +IMPL_LINK_NOARG(ScTpDefaultsOptions, PrefixModifiedHdl, weld::Entry&, void) +{ + CheckPrefix(); +} + +IMPL_LINK_NOARG(ScTpDefaultsOptions, PrefixEditOnFocusHdl, weld::Widget&, void) +{ + OnFocusPrefixInput(); +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |