/* -*- 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 #include #include #include #include #include #include #include "flddinf.hxx" #include #include #include #include #include #include #define USER_DATA_VERSION_1 "1" #define USER_DATA_VERSION USER_DATA_VERSION_1 using namespace nsSwDocInfoSubType; using namespace com::sun::star; void FillFieldSelect(ListBox& rListBox) { for (size_t i = 0; i < SAL_N_ELEMENTS(FLD_SELECT); ++i) rListBox.InsertEntry(SwResId(FLD_SELECT[i])); } SwFieldDokInfPage::SwFieldDokInfPage(vcl::Window* pParent, const SfxItemSet *const pCoreSet) : SwFieldPage(pParent, "FieldDocInfoPage", "modules/swriter/ui/flddocinfopage.ui", pCoreSet) , pSelEntry(nullptr) , nOldSel(0) , nOldFormat(0) { get(m_pTypeTLB, "type"); get(m_pSelection, "selectframe"); get(m_pFormat, "formatframe"); get(m_pSelectionLB, "select"); FillFieldSelect(*m_pSelectionLB); get(m_pFormatLB, "format"); get(m_pFixedCB, "fixed"); long nHeight = m_pTypeTLB->GetTextHeight() * 20; m_pTypeTLB->set_height_request(nHeight); m_pSelectionLB->set_height_request(nHeight); m_pFormatLB->set_height_request(nHeight); long nWidth = m_pTypeTLB->LogicToPixel(Size(FIELD_COLUMN_WIDTH, 0), MapMode(MapUnit::MapAppFont)).Width(); m_pTypeTLB->set_width_request(nWidth); m_pFormatLB->set_width_request(nWidth); m_pSelectionLB->set_width_request(nWidth); m_pTypeTLB->SetSelectionMode(SelectionMode::Single); m_pTypeTLB->SetStyle(m_pTypeTLB->GetStyle()|WB_HASLINES|WB_CLIPCHILDREN|WB_SORT|WB_HASBUTTONS|WB_HASBUTTONSATROOT|WB_HSCROLL); m_pTypeTLB->SetOptimalImageIndent(); // Don't set font, so that the control's font is adopted! // Otherwise at wrong font bug to OV. m_pTypeTLB->SetSpaceBetweenEntries(0); m_pTypeTLB->SetNodeDefaultImages(); //enable 'active' language selection m_pFormatLB->SetShowLanguageControl(true); const SfxUnoAnyItem* pItem = pCoreSet ? pCoreSet->GetItem(SID_DOCINFO, false) : nullptr; if ( pItem ) pItem->GetValue() >>= xCustomPropertySet; } SwFieldDokInfPage::~SwFieldDokInfPage() { disposeOnce(); } void SwFieldDokInfPage::dispose() { m_pTypeTLB.clear(); m_pSelection.clear(); m_pSelectionLB.clear(); m_pFormat.clear(); m_pFormatLB.clear(); m_pFixedCB.clear(); SwFieldPage::dispose(); } void SwFieldDokInfPage::Reset(const SfxItemSet* ) { Init(); // general initialisation // initialise TypeListBox m_pTypeTLB->SetUpdateMode(false); m_pTypeTLB->Clear(); pSelEntry = nullptr; // display SubTypes in TypeLB SvTreeListEntry* pEntry = nullptr; SvTreeListEntry* pInfo = nullptr; sal_uInt16 nSubType = USHRT_MAX; if (IsFieldEdit()) { const SwField* pCurField = GetCurField(); nSubType = static_cast(pCurField)->GetSubType() & 0xff; if( nSubType == DI_CUSTOM ) { m_sOldCustomFieldName = static_cast(pCurField)->GetName(); } m_pFormatLB->SetAutomaticLanguage(pCurField->IsAutomaticLanguage()); SwWrtShell *pSh = GetWrtShell(); if(pSh) { const SvNumberformat* pFormat = pSh->GetNumberFormatter()->GetEntry(pCurField->GetFormat()); if(pFormat) m_pFormatLB->SetLanguage(pFormat->GetLanguage()); } } sal_Int32 nSelEntryData = LISTBOX_ENTRY_NOTFOUND; const OUString sUserData = GetUserData(); sal_Int32 nIdx{ 0 }; if (sUserData.getToken(0, ';', nIdx).equalsIgnoreAsciiCase(USER_DATA_VERSION_1)) { nSelEntryData = sUserData.getToken(0, ';', nIdx).toInt32(); } std::vector aLst; GetFieldMgr().GetSubTypes(TYP_DOCINFOFLD, aLst); for(size_t i = 0; i < aLst.size(); ++i) { if (!IsFieldEdit() || nSubType == i) { if (DI_CUSTOM == i) { if(xCustomPropertySet.is() ) { uno::Reference< beans::XPropertySetInfo > xSetInfo = xCustomPropertySet->getPropertySetInfo(); const uno::Sequence< beans::Property > rProperties = xSetInfo->getProperties(); if( rProperties.getLength() ) { pInfo = m_pTypeTLB->InsertEntry(SwResId(STR_CUSTOM_FIELD)); pInfo->SetUserData(reinterpret_cast(USHRT_MAX)); for (sal_Int32 n=0; n < rProperties.getLength(); n++) { const OUString sEntry = rProperties[n].Name; pEntry = m_pTypeTLB->InsertEntry(sEntry, pInfo); if (m_sOldCustomFieldName == sEntry) { pSelEntry = pEntry; m_pTypeTLB->Expand( pInfo ); } pEntry->SetUserData(reinterpret_cast(i)); } } } } else { if (!(IsFieldDlgHtmlMode() && (i == DI_EDIT || i == DI_THEMA || i == DI_PRINT))) { pEntry = m_pTypeTLB->InsertEntry(aLst[i]); pEntry->SetUserData(reinterpret_cast(i)); } } if(static_cast(nSelEntryData) == i) pSelEntry = pEntry; } } // select old Pos if (pSelEntry != nullptr) { m_pTypeTLB->Select(pSelEntry); nSubType = static_cast(reinterpret_cast(pSelEntry->GetUserData())); } else if ( m_pTypeTLB->GetEntry(0) ) { pSelEntry = m_pTypeTLB->GetEntry(0); nSubType = static_cast(reinterpret_cast(pSelEntry->GetUserData())); } FillSelectionLB(nSubType); if ( pSelEntry ) TypeHdl(nullptr); m_pTypeTLB->SetUpdateMode(true); m_pTypeTLB->SetSelectHdl(LINK(this, SwFieldDokInfPage, TypeHdl)); m_pTypeTLB->SetDoubleClickHdl(LINK(this, SwFieldDokInfPage, TreeListBoxInsertHdl)); m_pSelectionLB->SetSelectHdl(LINK(this, SwFieldDokInfPage, SubTypeHdl)); m_pSelectionLB->SetDoubleClickHdl(LINK(this, SwFieldDokInfPage, ListBoxInsertHdl)); m_pFormatLB->SetDoubleClickHdl(LINK(this, SwFieldDokInfPage, ListBoxInsertHdl)); if (IsFieldEdit()) { nOldSel = m_pSelectionLB->GetSelectedEntryPos(); nOldFormat = GetCurField()->GetFormat(); m_pFixedCB->SaveValue(); } } IMPL_LINK_NOARG(SwFieldDokInfPage, TypeHdl, SvTreeListBox*, void) { // save old ListBoxPos SvTreeListEntry* pOldEntry = pSelEntry; // current ListBoxPos pSelEntry = m_pTypeTLB->FirstSelected(); if(!pSelEntry) { pSelEntry = m_pTypeTLB->GetEntry(0); m_pTypeTLB->Select(pSelEntry); } else if (pOldEntry != pSelEntry) FillSelectionLB(static_cast(reinterpret_cast(pSelEntry->GetUserData()))); SubTypeHdl(*m_pSelectionLB); } IMPL_LINK_NOARG(SwFieldDokInfPage, SubTypeHdl, ListBox&, void) { sal_uInt16 nSubType = static_cast(reinterpret_cast(pSelEntry->GetUserData())); sal_Int32 nPos = m_pSelectionLB->GetSelectedEntryPos(); sal_uInt16 nExtSubType; SvNumFormatType nNewType = SvNumFormatType::ALL; if (nSubType != DI_EDIT) { if (nPos == LISTBOX_ENTRY_NOTFOUND) { if (!m_pSelectionLB->GetEntryCount()) { m_pFormatLB->Clear(); m_pFormat->Enable(false); if( nSubType == DI_CUSTOM ) { //find out which type the custom field has - for a start set to DATE format const OUString sName = m_pTypeTLB->GetEntryText(pSelEntry); try { uno::Any aVal = xCustomPropertySet->getPropertyValue( sName ); const uno::Type& rValueType = aVal.getValueType(); if( rValueType == ::cppu::UnoType::get()) { nNewType = SvNumFormatType::DATETIME; } else if( rValueType == ::cppu::UnoType::get()) { nNewType = SvNumFormatType::DATE; } else if( rValueType == ::cppu::UnoType::get()) { nNewType = SvNumFormatType::TIME; } } catch( const uno::Exception& ) { } } else return; } nPos = 0; } nExtSubType = static_cast(reinterpret_cast(m_pSelectionLB->GetEntryData(nPos))); } else nExtSubType = DI_SUB_TIME; SvNumFormatType nOldType = SvNumFormatType::ALL; bool bEnable = false; bool bOneArea = false; if (m_pFormatLB->IsEnabled()) nOldType = m_pFormatLB->GetFormatType(); switch (nExtSubType) { case DI_SUB_AUTHOR: break; case DI_SUB_DATE: nNewType = SvNumFormatType::DATE; bOneArea = true; break; case DI_SUB_TIME: nNewType = SvNumFormatType::TIME; bOneArea = true; break; } if (nNewType == SvNumFormatType::ALL) { m_pFormatLB->Clear(); } else { if (nOldType != nNewType) { m_pFormatLB->SetFormatType(nNewType); m_pFormatLB->SetOneArea(bOneArea); } bEnable = true; } sal_uInt32 nFormat = IsFieldEdit() ? static_cast(GetCurField())->GetFormat() : 0; sal_uInt16 nOldSubType = IsFieldEdit() ? (static_cast(GetCurField())->GetSubType() & 0xff00) : 0; if (IsFieldEdit()) { nPos = m_pSelectionLB->GetSelectedEntryPos(); if (nPos != LISTBOX_ENTRY_NOTFOUND ) { nSubType = static_cast(reinterpret_cast(m_pSelectionLB->GetEntryData(nPos))); nOldSubType &= ~DI_SUB_FIXED; if (nOldSubType == nSubType) { if (!nFormat && (nNewType == SvNumFormatType::DATE || nNewType == SvNumFormatType::TIME)) { SwWrtShell *pSh = GetWrtShell(); if(pSh) { SvNumberFormatter* pFormatter = pSh->GetNumberFormatter(); LanguageType eLang = m_pFormatLB->GetCurLanguage(); if (nNewType == SvNumFormatType::DATE) nFormat = pFormatter->GetFormatIndex( NF_DATE_SYSTEM_SHORT, eLang); else if (nNewType == SvNumFormatType::TIME) nFormat = pFormatter->GetFormatIndex( NF_TIME_HHMM, eLang); } } m_pFormatLB->SetDefFormat(nFormat); } } else if( (nSubType == DI_CUSTOM) && (nNewType != SvNumFormatType::ALL) ) { m_pFormatLB->SetDefFormat(nFormat); } } m_pFormat->Enable(bEnable); if (bEnable && m_pFormatLB->GetSelectedEntryPos() == LISTBOX_ENTRY_NOTFOUND) { m_pFormatLB->SelectEntryPos(0); } } sal_Int32 SwFieldDokInfPage::FillSelectionLB(sal_uInt16 nSubType) { // fill Format-Listbox sal_uInt16 nTypeId = TYP_DOCINFOFLD; EnableInsert(nSubType != USHRT_MAX); if (nSubType == USHRT_MAX) // Info-Text nSubType = DI_SUBTYPE_BEGIN; m_pSelectionLB->Clear(); sal_uInt16 nSize = 0; sal_Int32 nSelPos = LISTBOX_ENTRY_NOTFOUND; sal_uInt16 nExtSubType = IsFieldEdit() ? (static_cast(GetCurField())->GetSubType() & 0xff00) : 0; if (IsFieldEdit()) { m_pFixedCB->Check((nExtSubType & DI_SUB_FIXED) != 0); nExtSubType = ((nExtSubType & ~DI_SUB_FIXED) >> 8) - 1; } if (nSubType < DI_CREATE || nSubType == DI_DOCNO || nSubType == DI_EDIT|| nSubType == DI_CUSTOM ) { // Format Box is empty for Title and Time } else { nSize = GetFieldMgr().GetFormatCount(nTypeId, IsFieldDlgHtmlMode()); for (sal_uInt16 i = 0; i < nSize; i++) { sal_Int32 nPos = m_pSelectionLB->InsertEntry(GetFieldMgr().GetFormatStr(nTypeId, i)); m_pSelectionLB->SetEntryData(nPos, reinterpret_cast(GetFieldMgr().GetFormatId(nTypeId, i))); if (IsFieldEdit() && i == nExtSubType) nSelPos = nPos; } } bool bEnable = nSize != 0; if (nSize) { if (!m_pSelectionLB->GetSelectedEntryCount()) m_pSelectionLB->SelectEntryPos(nSelPos == USHRT_MAX ? 0 : nSelPos); bEnable = true; } m_pSelection->Enable(bEnable); return nSize; } bool SwFieldDokInfPage::FillItemSet(SfxItemSet* ) { if (!pSelEntry || static_cast(reinterpret_cast(pSelEntry->GetUserData())) == USHRT_MAX) return false; sal_uInt16 nSubType = static_cast(reinterpret_cast(pSelEntry->GetUserData())); sal_uInt32 nFormat = 0; sal_Int32 nPos = m_pSelectionLB->GetSelectedEntryPos(); OUString aName; if (DI_CUSTOM == nSubType) aName = m_pTypeTLB->GetEntryText(pSelEntry); if (nPos != LISTBOX_ENTRY_NOTFOUND) nSubType |= static_cast(reinterpret_cast(m_pSelectionLB->GetEntryData(nPos))); if (m_pFixedCB->IsChecked()) nSubType |= DI_SUB_FIXED; nPos = m_pFormatLB->GetSelectedEntryPos(); if(nPos != LISTBOX_ENTRY_NOTFOUND) nFormat = m_pFormatLB->GetFormat(); if (!IsFieldEdit() || nOldSel != m_pSelectionLB->GetSelectedEntryPos() || nOldFormat != nFormat || m_pFixedCB->IsValueChangedFromSaved() || (DI_CUSTOM == nSubType && aName != m_sOldCustomFieldName )) { InsertField(TYP_DOCINFOFLD, nSubType, aName, OUString(), nFormat, ' ', m_pFormatLB->IsAutomaticLanguage()); } return false; } VclPtr SwFieldDokInfPage::Create( TabPageParent pParent, const SfxItemSet *const pAttrSet) { return VclPtr::Create( pParent.pParent, pAttrSet ); } sal_uInt16 SwFieldDokInfPage::GetGroup() { return GRP_REG; } void SwFieldDokInfPage::FillUserData() { SvTreeListEntry* pEntry = m_pTypeTLB->FirstSelected(); sal_uInt16 nTypeSel = pEntry ? sal::static_int_cast< sal_uInt16 >(reinterpret_cast< sal_uIntPtr >(pEntry->GetUserData())) : USHRT_MAX; SetUserData(USER_DATA_VERSION ";" + OUString::number( nTypeSel )); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */