/* -*- 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 "fldref.hxx" #include #include #include #include #include #include #include #include #include #include #include #define REFFLDFLAG 0x4000 #define REFFLDFLAG_BOOKMARK 0x4800 #define REFFLDFLAG_FOOTNOTE 0x5000 #define REFFLDFLAG_ENDNOTE 0x6000 // #i83479# #define REFFLDFLAG_HEADING 0x7100 #define REFFLDFLAG_NUMITEM 0x7200 static sal_uInt16 nFieldDlgFormatSel = 0; #define USER_DATA_VERSION_1 "1" #define USER_DATA_VERSION USER_DATA_VERSION_1 SwFieldRefPage::SwFieldRefPage(vcl::Window* pParent, const SfxItemSet *const pCoreSet ) : SwFieldPage(pParent, "FieldRefPage", "modules/swriter/ui/fldrefpage.ui", pCoreSet) , maOutlineNodes() , maNumItems() , mpSavedSelectedTextNode(nullptr) , mnSavedSelectedPos(0) { get(m_pTypeLB, "type"); get(m_pSelection, "selectframe"); get(m_pSelectionLB, "select"); m_pSelectionLB->SetStyle(m_pSelectionLB->GetStyle() | WB_SORT); // #i83479# get(m_pSelectionToolTipLB, "selecttip"); get(m_pFormat, "formatframe"); get(m_pFormatLB, "format"); get(m_pNameFT, "nameft"); get(m_pNameED, "name"); get(m_pValueED, "value"); get(m_pFilterED, "filter"); sBookmarkText = m_pTypeLB->GetEntry(0); sFootnoteText = m_pTypeLB->GetEntry(1); sEndnoteText = m_pTypeLB->GetEntry(2); // #i83479# sHeadingText = m_pTypeLB->GetEntry(3); sNumItemText = m_pTypeLB->GetEntry(4); m_pTypeLB->Clear(); long nHeight = m_pTypeLB->GetTextHeight() * 20; m_pSelection->set_height_request(nHeight); m_pSelectionToolTipLB->set_height_request(nHeight); nHeight = m_pTypeLB->GetTextHeight() * 8; m_pTypeLB->set_height_request(nHeight); m_pFormatLB->set_height_request(nHeight); long nWidth = m_pTypeLB->LogicToPixel(Size(FIELD_COLUMN_WIDTH, 0), MapMode(MapUnit::MapAppFont)).Width(); m_pTypeLB->set_width_request(nWidth); m_pFormatLB->set_width_request(nWidth); m_pSelection->set_width_request(nWidth*2); m_pSelectionToolTipLB->set_width_request(nWidth*2); m_pNameED->SetModifyHdl(LINK(this, SwFieldRefPage, ModifyHdl)); m_pFilterED->SetModifyHdl( LINK( this, SwFieldRefPage, ModifyHdl_Impl ) ); m_pTypeLB->SetDoubleClickHdl (LINK(this, SwFieldRefPage, ListBoxInsertHdl)); m_pTypeLB->SetSelectHdl (LINK(this, SwFieldRefPage, TypeHdl)); m_pSelectionLB->SetSelectHdl (LINK(this, SwFieldRefPage, SubTypeListBoxHdl)); m_pSelectionLB->SetDoubleClickHdl (LINK(this, SwFieldRefPage, ListBoxInsertHdl)); m_pFormatLB->SetDoubleClickHdl (LINK(this, SwFieldRefPage, ListBoxInsertHdl)); // #i83479# m_pSelectionToolTipLB->SetSelectHdl( LINK(this, SwFieldRefPage, SubTypeTreeListBoxHdl) ); m_pSelectionToolTipLB->SetDoubleClickHdl( LINK(this, SwFieldRefPage, TreeListBoxInsertHdl) ); m_pSelectionToolTipLB->SetStyle( m_pSelectionToolTipLB->GetStyle() | WB_HSCROLL ); m_pSelectionToolTipLB->SetSpaceBetweenEntries(1); m_pSelectionToolTipLB->SetHighlightRange(); } SwFieldRefPage::~SwFieldRefPage() { disposeOnce(); } void SwFieldRefPage::dispose() { m_pTypeLB.clear(); m_pSelection.clear(); m_pSelectionLB.clear(); m_pSelectionToolTipLB.clear(); m_pFormat.clear(); m_pFormatLB.clear(); m_pNameFT.clear(); m_pNameED.clear(); m_pFilterED.clear(); m_pValueED.clear(); SwFieldPage::dispose(); } IMPL_LINK_NOARG(SwFieldRefPage, ModifyHdl_Impl, Edit&, void) { OUString sFilter = comphelper::string::strip(m_pFilterED->GetText(), ' '); UpdateSubType(sFilter); } // #i83479# void SwFieldRefPage::SaveSelectedTextNode() { mpSavedSelectedTextNode = nullptr; mnSavedSelectedPos = 0; if ( m_pSelectionToolTipLB->IsVisible() ) { SvTreeListEntry* pEntry = m_pSelectionToolTipLB->GetCurEntry(); if ( pEntry ) { const sal_uInt16 nTypeId = static_cast(reinterpret_cast(m_pTypeLB->GetEntryData(GetTypeSel()))); if ( nTypeId == REFFLDFLAG_HEADING ) { mnSavedSelectedPos = static_cast(reinterpret_cast(pEntry->GetUserData())); if ( mnSavedSelectedPos < maOutlineNodes.size() ) { mpSavedSelectedTextNode = maOutlineNodes[mnSavedSelectedPos]; } } else if ( nTypeId == REFFLDFLAG_NUMITEM ) { mnSavedSelectedPos = static_cast(reinterpret_cast(pEntry->GetUserData())); if ( mnSavedSelectedPos < maNumItems.size() ) { mpSavedSelectedTextNode = maNumItems[mnSavedSelectedPos]->GetTextNode(); } } } } } void SwFieldRefPage::Reset(const SfxItemSet* ) { if (!IsFieldEdit()) { SavePos(m_pTypeLB); // #i83479# SaveSelectedTextNode(); } SetSelectionSel(LISTBOX_ENTRY_NOTFOUND); SetTypeSel(LISTBOX_ENTRY_NOTFOUND); Init(); // general initialisation // initialise TypeListBox m_pTypeLB->SetUpdateMode(false); m_pTypeLB->Clear(); // fill Type-Listbox sal_Int32 nPos; // set/insert reference const SwFieldGroupRgn& rRg = SwFieldMgr::GetGroupRange(IsFieldDlgHtmlMode(), GetGroup()); for (short i = rRg.nStart; i < rRg.nEnd; ++i) { const sal_uInt16 nTypeId = SwFieldMgr::GetTypeId(i); if (!IsFieldEdit() || nTypeId != TYP_SETREFFLD) { nPos = m_pTypeLB->InsertEntry(SwFieldMgr::GetTypeStr(i), i - rRg.nStart); m_pTypeLB->SetEntryData(nPos, reinterpret_cast(nTypeId)); } } // #i83479# // entries for headings and numbered items nPos = m_pTypeLB->InsertEntry(sHeadingText); m_pTypeLB->SetEntryData(nPos, reinterpret_cast(REFFLDFLAG_HEADING)); nPos = m_pTypeLB->InsertEntry(sNumItemText); m_pTypeLB->SetEntryData(nPos, reinterpret_cast(REFFLDFLAG_NUMITEM)); // fill up with the sequence types SwWrtShell *pSh = GetWrtShell(); if (!pSh) pSh = ::GetActiveWrtShell(); if (!pSh) return; const size_t nFieldTypeCnt = pSh->GetFieldTypeCount(SwFieldIds::SetExp); OSL_ENSURE( nFieldTypeCnt < static_cast(REFFLDFLAG), " - Item index will overlap flags!" ); for (size_t n = 0; n < nFieldTypeCnt; ++n) { SwSetExpFieldType* pType = static_cast(pSh->GetFieldType(n, SwFieldIds::SetExp)); if ((nsSwGetSetExpType::GSE_SEQ & pType->GetType()) && pType->HasWriterListeners() && pSh->IsUsed(*pType)) { nPos = m_pTypeLB->InsertEntry(pType->GetName()); m_pTypeLB->SetEntryData(nPos, reinterpret_cast(static_cast(REFFLDFLAG | n))); } } // text marks - now always (because of globaldocuments) nPos = m_pTypeLB->InsertEntry(sBookmarkText); m_pTypeLB->SetEntryData(nPos, reinterpret_cast(REFFLDFLAG_BOOKMARK)); // footnotes: if( pSh->HasFootnotes() ) { nPos = m_pTypeLB->InsertEntry(sFootnoteText); m_pTypeLB->SetEntryData(nPos, reinterpret_cast(REFFLDFLAG_FOOTNOTE)); } // endnotes: if ( pSh->HasFootnotes(true) ) { nPos = m_pTypeLB->InsertEntry(sEndnoteText); m_pTypeLB->SetEntryData(nPos, reinterpret_cast(REFFLDFLAG_ENDNOTE)); } // select old Pos if (!IsFieldEdit()) RestorePos(m_pTypeLB); m_pTypeLB->SetUpdateMode(true); nFieldDlgFormatSel = 0; sal_uInt16 nFormatBoxPosition = USHRT_MAX; if( !IsRefresh() ) { OUString sUserData = GetUserData(); if(!IsRefresh() && sUserData.getToken(0, ';'). equalsIgnoreAsciiCase(USER_DATA_VERSION_1)) { OUString sVal = sUserData.getToken(1, ';'); const sal_uInt16 nVal = static_cast< sal_uInt16 >(sVal.toInt32()); if(nVal != USHRT_MAX) { for(sal_Int32 i = 0; i < m_pTypeLB->GetEntryCount(); i++) { if(nVal == static_cast(reinterpret_cast(m_pTypeLB->GetEntryData(i)))) { m_pTypeLB->SelectEntryPos(i); break; } } sVal = sUserData.getToken(2, ';'); if(!sVal.isEmpty()) { nFormatBoxPosition = static_cast< sal_uInt16 >(sVal.toInt32()); } } } } TypeHdl(*m_pTypeLB); if(nFormatBoxPosition != USHRT_MAX) { m_pFormatLB->SelectEntryPos(nFormatBoxPosition); } if (IsFieldEdit()) { m_pTypeLB->SaveValue(); m_pSelectionLB->SaveValue(); m_pFormatLB->SaveValue(); m_pNameED->SaveValue(); m_pValueED->SaveValue(); m_pFilterED->SetText(OUString()); } } IMPL_LINK_NOARG(SwFieldRefPage, TypeHdl, ListBox&, void) { // save old ListBoxPos const sal_Int32 nOld = GetTypeSel(); // current ListBoxPos SetTypeSel(m_pTypeLB->GetSelectedEntryPos()); if(GetTypeSel() == LISTBOX_ENTRY_NOTFOUND) { if (IsFieldEdit()) { // select positions OUString sName; sal_uInt16 nFlag = 0; switch( GetCurField()->GetSubType() ) { case REF_BOOKMARK: { // #i83479# SwGetRefField* pRefField = dynamic_cast(GetCurField()); if ( pRefField && pRefField->IsRefToHeadingCrossRefBookmark() ) { sName = sHeadingText; nFlag = REFFLDFLAG_HEADING; } else if ( pRefField && pRefField->IsRefToNumItemCrossRefBookmark() ) { sName = sNumItemText; nFlag = REFFLDFLAG_NUMITEM; } else { sName = sBookmarkText; nFlag = REFFLDFLAG_BOOKMARK; } } break; case REF_FOOTNOTE: sName = sFootnoteText; nFlag = REFFLDFLAG_FOOTNOTE; break; case REF_ENDNOTE: sName = sEndnoteText; nFlag = REFFLDFLAG_ENDNOTE; break; case REF_SETREFATTR: sName = SwResId(STR_GETREFFLD); nFlag = REF_SETREFATTR; break; case REF_SEQUENCEFLD: sName = static_cast(GetCurField())->GetSetRefName(); nFlag = REFFLDFLAG; break; } if (m_pTypeLB->GetEntryPos(sName) == LISTBOX_ENTRY_NOTFOUND) // reference to deleted mark { sal_Int32 nPos = m_pTypeLB->InsertEntry(sName); m_pTypeLB->SetEntryData(nPos, reinterpret_cast(nFlag)); } m_pTypeLB->SelectEntry(sName); SetTypeSel(m_pTypeLB->GetSelectedEntryPos()); } else { SetTypeSel(0); m_pTypeLB->SelectEntryPos(0); } } if (nOld == GetTypeSel()) return; sal_uInt16 nTypeId = static_cast(reinterpret_cast(m_pTypeLB->GetEntryData(GetTypeSel()))); // fill selection-ListBox OUString sFilter = comphelper::string::strip(m_pFilterED->GetText(), ' '); UpdateSubType(sFilter); bool bName = false; nFieldDlgFormatSel = 0; if ( ( !IsFieldEdit() || m_pSelectionLB->GetEntryCount() ) && nOld != LISTBOX_ENTRY_NOTFOUND ) { m_pNameED->SetText(aEmptyOUStr); m_pValueED->SetText(aEmptyOUStr); m_pFilterED->SetText(aEmptyOUStr); } switch (nTypeId) { case TYP_GETREFFLD: if (REFFLDFLAG & static_cast(reinterpret_cast(m_pTypeLB->GetEntryData(nOld)))) // the old one stays nFieldDlgFormatSel = m_pFormatLB->GetSelectedEntryPos(); bName = true; break; case TYP_SETREFFLD: bName = true; break; case REFFLDFLAG_BOOKMARK: bName = true; SAL_FALLTHROUGH; default: if( REFFLDFLAG & nTypeId ) { const sal_uInt16 nOldId = static_cast(reinterpret_cast(m_pTypeLB->GetEntryData(nOld))); if( nOldId & REFFLDFLAG || nOldId == TYP_GETREFFLD ) // then the old one stays nFieldDlgFormatSel = m_pFormatLB->GetSelectedEntryPos(); } break; } m_pNameED->Enable(bName); m_pNameFT->Enable(bName); // fill Format-Listbox sal_Int32 nSize = FillFormatLB(nTypeId); bool bFormat = nSize != 0; m_pFormat->Enable(bFormat); SubTypeHdl(); ModifyHdl(*m_pNameED); ModifyHdl(*m_pFilterED); } IMPL_LINK_NOARG(SwFieldRefPage, SubTypeTreeListBoxHdl, SvTreeListBox*, void) { SubTypeHdl(); } IMPL_LINK_NOARG(SwFieldRefPage, SubTypeListBoxHdl, ListBox&, void) { SubTypeHdl(); } void SwFieldRefPage::SubTypeHdl() { sal_uInt16 nTypeId = static_cast(reinterpret_cast(m_pTypeLB->GetEntryData(GetTypeSel()))); switch(nTypeId) { case TYP_GETREFFLD: if (!IsFieldEdit() || m_pSelectionLB->GetSelectedEntryCount()) { m_pNameED->SetText(m_pSelectionLB->GetSelectedEntry()); ModifyHdl(*m_pNameED); } break; case TYP_SETREFFLD: { SwWrtShell *pSh = GetWrtShell(); if(!pSh) pSh = ::GetActiveWrtShell(); if(pSh) { m_pValueED->SetText(pSh->GetSelText()); } } break; // #i83479# case REFFLDFLAG_HEADING: case REFFLDFLAG_NUMITEM: { if ( m_pSelectionToolTipLB->GetCurEntry() ) { m_pNameED->SetText( m_pSelectionToolTipLB->GetEntryText( m_pSelectionToolTipLB->GetCurEntry() ) ); } } break; default: if (!IsFieldEdit() || m_pSelectionLB->GetSelectedEntryCount()) m_pNameED->SetText(m_pSelectionLB->GetSelectedEntry()); break; } } // renew types in SelectionLB after filtering void SwFieldRefPage::UpdateSubType(const OUString& filterString) { SwWrtShell *pSh = GetWrtShell(); if(!pSh) pSh = ::GetActiveWrtShell(); SwGetRefField* pRefField = static_cast(GetCurField()); const sal_uInt16 nTypeId = static_cast(reinterpret_cast(m_pTypeLB->GetEntryData(GetTypeSel()))); OUString sOldSel; // #i83479# if ( m_pSelectionLB->IsVisible() ) { const sal_Int32 nSelectionSel = m_pSelectionLB->GetSelectedEntryPos(); if (nSelectionSel != LISTBOX_ENTRY_NOTFOUND) { sOldSel = m_pSelectionLB->GetEntry(nSelectionSel); } } if (IsFieldEdit() && sOldSel.isEmpty()) sOldSel = OUString::number( pRefField->GetSeqNo() + 1 ); m_pSelectionLB->SetUpdateMode(false); m_pSelectionLB->Clear(); // #i83479# m_pSelectionToolTipLB->SetUpdateMode(false); m_pSelectionToolTipLB->Clear(); bool bShowSelectionToolTipLB( false ); if( REFFLDFLAG & nTypeId ) { if (nTypeId == REFFLDFLAG_BOOKMARK) // text marks! { m_pSelectionLB->SetStyle(m_pSelectionLB->GetStyle()|WB_SORT); // get all text marks IDocumentMarkAccess* const pMarkAccess = pSh->getIDocumentMarkAccess(); for(IDocumentMarkAccess::const_iterator_t ppMark = pMarkAccess->getBookmarksBegin(); ppMark != pMarkAccess->getBookmarksEnd(); ++ppMark) { const ::sw::mark::IMark* pBkmk = ppMark->get(); if(IDocumentMarkAccess::MarkType::BOOKMARK == IDocumentMarkAccess::GetType(*pBkmk)) { bool isSubstring = MatchSubstring(pBkmk->GetName(), filterString); if(isSubstring) { m_pSelectionLB->InsertEntry( pBkmk->GetName() ); } } } if (IsFieldEdit()) sOldSel = pRefField->GetSetRefName(); } else if (nTypeId == REFFLDFLAG_FOOTNOTE) { m_pSelectionLB->SetStyle(m_pSelectionLB->GetStyle() & ~WB_SORT); SwSeqFieldList aArr; const size_t nCnt = pSh->GetSeqFootnoteList( aArr ); for( size_t n = 0; n < nCnt; ++n ) { bool isSubstring = MatchSubstring(aArr[ n ].sDlgEntry, filterString); if(isSubstring) { m_pSelectionLB->InsertEntry( aArr[ n ].sDlgEntry ); } if (IsFieldEdit() && pRefField->GetSeqNo() == aArr[ n ].nSeqNo) sOldSel = aArr[n].sDlgEntry; } } else if (nTypeId == REFFLDFLAG_ENDNOTE) { m_pSelectionLB->SetStyle(m_pSelectionLB->GetStyle() & ~WB_SORT); SwSeqFieldList aArr; const size_t nCnt = pSh->GetSeqFootnoteList( aArr, true ); for( size_t n = 0; n < nCnt; ++n ) { bool isSubstring = MatchSubstring(aArr[ n ].sDlgEntry, filterString); if(isSubstring) { m_pSelectionLB->InsertEntry( aArr[ n ].sDlgEntry ); } if (IsFieldEdit() && pRefField->GetSeqNo() == aArr[ n ].nSeqNo) sOldSel = aArr[n].sDlgEntry; } } // #i83479# else if ( nTypeId == REFFLDFLAG_HEADING ) { bShowSelectionToolTipLB = true; const IDocumentOutlineNodes* pIDoc( pSh->getIDocumentOutlineNodesAccess() ); pIDoc->getOutlineNodes( maOutlineNodes ); bool bCertainTextNodeSelected( false ); for ( size_t nOutlIdx = 0; nOutlIdx < maOutlineNodes.size(); ++nOutlIdx ) { bool isSubstring = MatchSubstring(pIDoc->getOutlineText( nOutlIdx, true, true, false ), filterString); if(isSubstring) { SvTreeListEntry* pEntry = m_pSelectionToolTipLB->InsertEntry( pIDoc->getOutlineText( nOutlIdx, true, true, false ) ); pEntry->SetUserData( reinterpret_cast(nOutlIdx) ); if ( ( IsFieldEdit() && pRefField->GetReferencedTextNode() == maOutlineNodes[nOutlIdx] ) || mpSavedSelectedTextNode == maOutlineNodes[nOutlIdx] ) { m_pSelectionToolTipLB->Select( pEntry ); sOldSel.clear(); bCertainTextNodeSelected = true; } else if ( !bCertainTextNodeSelected && mnSavedSelectedPos == nOutlIdx ) { m_pSelectionToolTipLB->Select( pEntry ); sOldSel.clear(); } } } } else if ( nTypeId == REFFLDFLAG_NUMITEM ) { bShowSelectionToolTipLB = true; const IDocumentListItems* pIDoc( pSh->getIDocumentListItemsAccess() ); pIDoc->getNumItems( maNumItems ); bool bCertainTextNodeSelected( false ); for ( size_t nNumItemIdx = 0; nNumItemIdx < maNumItems.size(); ++nNumItemIdx ) { bool isSubstring = MatchSubstring(pIDoc->getListItemText( *maNumItems[nNumItemIdx] ), filterString); if(isSubstring) { SvTreeListEntry* pEntry = m_pSelectionToolTipLB->InsertEntry( pIDoc->getListItemText( *maNumItems[nNumItemIdx] ) ); pEntry->SetUserData( reinterpret_cast(nNumItemIdx) ); if ( ( IsFieldEdit() && pRefField->GetReferencedTextNode() == maNumItems[nNumItemIdx]->GetTextNode() ) || mpSavedSelectedTextNode == maNumItems[nNumItemIdx]->GetTextNode() ) { m_pSelectionToolTipLB->Select( pEntry ); sOldSel.clear(); bCertainTextNodeSelected = true; } else if ( !bCertainTextNodeSelected && mnSavedSelectedPos == nNumItemIdx ) { m_pSelectionToolTipLB->Select( pEntry ); sOldSel.clear(); } } } } else { m_pSelectionLB->SetStyle(m_pSelectionLB->GetStyle()|WB_SORT); // get the fields to Seq-FieldType: SwSetExpFieldType* pType = static_cast(pSh->GetFieldType( nTypeId & ~REFFLDFLAG, SwFieldIds::SetExp )); if( pType ) { SwSeqFieldList aArr; // old selection should be kept in non-edit mode if(IsFieldEdit()) sOldSel.clear(); const size_t nCnt = pType->GetSeqFieldList( aArr ); for( size_t n = 0; n < nCnt; ++n ) { bool isSubstring = MatchSubstring(aArr[ n ].sDlgEntry, filterString); if(isSubstring) { m_pSelectionLB->InsertEntry( aArr[ n ].sDlgEntry ); } if (IsFieldEdit() && sOldSel.isEmpty() && aArr[ n ].nSeqNo == pRefField->GetSeqNo()) sOldSel = aArr[ n ].sDlgEntry; } if (IsFieldEdit() && sOldSel.isEmpty()) sOldSel = OUString::number( pRefField->GetSeqNo() + 1); } } } else { std::vector aLst; GetFieldMgr().GetSubTypes(nTypeId, aLst); for(const OUString & i : aLst) { bool isSubstring = MatchSubstring( i , filterString ); if(isSubstring) { m_pSelectionLB->InsertEntry(i); } } if (IsFieldEdit()) sOldSel = pRefField->GetSetRefName(); } // #i83479# m_pSelectionToolTipLB->Show( bShowSelectionToolTipLB ); m_pSelectionLB->Show( !bShowSelectionToolTipLB ); if ( bShowSelectionToolTipLB ) { m_pSelectionToolTipLB->SetUpdateMode(true); bool bEnable = m_pSelectionToolTipLB->GetEntryCount() != 0; m_pSelection->Enable( bEnable ); if ( m_pSelectionToolTipLB->GetCurEntry() != nullptr ) { m_pSelectionToolTipLB->MakeVisible( m_pSelectionToolTipLB->GetCurEntry() ); } if ( IsFieldEdit() && m_pSelectionToolTipLB->GetCurEntry() == nullptr ) { m_pNameED->SetText(sOldSel); } } else { m_pSelectionLB->SetUpdateMode(true); // enable or disable bool bEnable = m_pSelectionLB->GetEntryCount() != 0; m_pSelection->Enable( bEnable ); if ( bEnable ) { m_pSelectionLB->SelectEntry(sOldSel); if (!m_pSelectionLB->GetSelectedEntryCount() && !IsFieldEdit()) m_pSelectionLB->SelectEntryPos(0); } if (IsFieldEdit() && !m_pSelectionLB->GetSelectedEntryCount()) // in case the reference was already deleted... m_pNameED->SetText(sOldSel); } } bool SwFieldRefPage::MatchSubstring( const OUString& rListString, const OUString& rSubstr ) { if(rSubstr.isEmpty()) return true; OUString aListString = GetAppCharClass().lowercase(rListString); OUString aSubstr = GetAppCharClass().lowercase(rSubstr); return aListString.indexOf(aSubstr) >= 0; } enum FMT_REF_IDX { FMT_REF_PAGE_IDX = 0, FMT_REF_CHAPTER_IDX = 1, FMT_REF_TEXT_IDX = 2, FMT_REF_UPDOWN_IDX = 3, FMT_REF_PAGE_PGDSC_IDX = 4, FMT_REF_ONLYNUMBER_IDX = 5, FMT_REF_ONLYCAPTION_IDX = 6, FMT_REF_ONLYSEQNO_IDX = 7, FMT_REF_NUMBER_IDX = 8, FMT_REF_NUMBER_NO_CONTEXT_IDX = 9, FMT_REF_NUMBER_FULL_CONTEXT_IDX = 10 }; static const char* FMT_REF_ARY[] = { FMT_REF_PAGE, FMT_REF_CHAPTER, FMT_REF_TEXT, FMT_REF_UPDOWN, FMT_REF_PAGE_PGDSC, FMT_REF_ONLYNUMBER, FMT_REF_ONLYCAPTION, FMT_REF_ONLYSEQNO, FMT_REF_NUMBER, FMT_REF_NUMBER_NO_CONTEXT, FMT_REF_NUMBER_FULL_CONTEXT }; sal_Int32 SwFieldRefPage::FillFormatLB(sal_uInt16 nTypeId) { OUString sOldSel; sal_Int32 nFormatSel = m_pFormatLB->GetSelectedEntryPos(); if (nFormatSel != LISTBOX_ENTRY_NOTFOUND) sOldSel = m_pFormatLB->GetEntry(nFormatSel); // fill Format-Listbox m_pFormatLB->Clear(); // reference has less that the annotation sal_uInt16 nSize( 0 ); bool bAddCrossRefFormats( false ); switch (nTypeId) { // #i83479# case REFFLDFLAG_HEADING: case REFFLDFLAG_NUMITEM: bAddCrossRefFormats = true; SAL_FALLTHROUGH; case TYP_GETREFFLD: case REFFLDFLAG_BOOKMARK: case REFFLDFLAG_FOOTNOTE: case REFFLDFLAG_ENDNOTE: nSize = FMT_REF_PAGE_PGDSC_IDX + 1; break; default: // #i83479# if ( REFFLDFLAG & nTypeId ) { nSize = FMT_REF_ONLYSEQNO_IDX + 1; } else { nSize = GetFieldMgr().GetFormatCount( nTypeId, IsFieldDlgHtmlMode() ); } break; } if (REFFLDFLAG & nTypeId) nTypeId = TYP_GETREFFLD; for (sal_uInt16 i = 0; i < nSize; i++) { sal_Int32 nPos = m_pFormatLB->InsertEntry(GetFieldMgr().GetFormatStr( nTypeId, i )); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, i ))); } // #i83479# sal_uInt16 nExtraSize( 0 ); if ( bAddCrossRefFormats ) { sal_uInt16 nFormat = FMT_REF_NUMBER_IDX; sal_Int32 nPos = m_pFormatLB->InsertEntry(GetFieldMgr().GetFormatStr( nTypeId, nFormat )); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, nFormat ))); nFormat = FMT_REF_NUMBER_NO_CONTEXT_IDX; nPos = m_pFormatLB->InsertEntry(GetFieldMgr().GetFormatStr( nTypeId, nFormat )); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, nFormat ))); nFormat = FMT_REF_NUMBER_FULL_CONTEXT_IDX; nPos = m_pFormatLB->InsertEntry(GetFieldMgr().GetFormatStr( nTypeId, nFormat )); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, nFormat ))); nExtraSize = 3; } // extra list items optionally, depending from reference-language SvtSysLocaleOptions aSysLocaleOptions; static const LanguageTag& rLang = aSysLocaleOptions.GetRealLanguageTag(); if (rLang.getLanguage() == "hu") { for (sal_uInt16 i = 0; i < nSize; i++) { sal_Int32 nPos = m_pFormatLB->InsertEntry(SwResId(FMT_REF_WITH_LOWERCASE_HU_ARTICLE) + GetFieldMgr().GetFormatStr( nTypeId, i )); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, i + SAL_N_ELEMENTS(FMT_REF_ARY)))); } nExtraSize += nSize; if ( bAddCrossRefFormats ) { sal_uInt16 nFormat = FMT_REF_NUMBER_IDX + SAL_N_ELEMENTS(FMT_REF_ARY); sal_Int32 nPos = m_pFormatLB->InsertEntry(SwResId(FMT_REF_WITH_LOWERCASE_HU_ARTICLE) + GetFieldMgr().GetFormatStr( nTypeId, nFormat % SAL_N_ELEMENTS(FMT_REF_ARY))); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, nFormat ))); nFormat = FMT_REF_NUMBER_NO_CONTEXT_IDX + SAL_N_ELEMENTS(FMT_REF_ARY); nPos = m_pFormatLB->InsertEntry(SwResId(FMT_REF_WITH_LOWERCASE_HU_ARTICLE) + GetFieldMgr().GetFormatStr( nTypeId, nFormat % SAL_N_ELEMENTS(FMT_REF_ARY))); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, nFormat ))); nFormat = FMT_REF_NUMBER_FULL_CONTEXT_IDX + SAL_N_ELEMENTS(FMT_REF_ARY); nPos = m_pFormatLB->InsertEntry(SwResId(FMT_REF_WITH_LOWERCASE_HU_ARTICLE) + GetFieldMgr().GetFormatStr( nTypeId, nFormat % SAL_N_ELEMENTS(FMT_REF_ARY))); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, nFormat ))); nExtraSize += 3; } // uppercase article for (sal_uInt16 i = 0; i < nSize; i++) { sal_Int32 nPos = m_pFormatLB->InsertEntry(SwResId(FMT_REF_WITH_UPPERCASE_HU_ARTICLE) + GetFieldMgr().GetFormatStr( nTypeId, i )); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, i + 2 * SAL_N_ELEMENTS(FMT_REF_ARY)))); } nExtraSize += nSize; if ( bAddCrossRefFormats ) { sal_uInt16 nFormat = FMT_REF_NUMBER_IDX + 2 * SAL_N_ELEMENTS(FMT_REF_ARY); sal_Int32 nPos = m_pFormatLB->InsertEntry(SwResId(FMT_REF_WITH_UPPERCASE_HU_ARTICLE) + GetFieldMgr().GetFormatStr( nTypeId, nFormat % SAL_N_ELEMENTS(FMT_REF_ARY))); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, nFormat ))); nFormat = FMT_REF_NUMBER_NO_CONTEXT_IDX + 2 * SAL_N_ELEMENTS(FMT_REF_ARY); nPos = m_pFormatLB->InsertEntry(SwResId(FMT_REF_WITH_UPPERCASE_HU_ARTICLE) + GetFieldMgr().GetFormatStr( nTypeId, nFormat % SAL_N_ELEMENTS(FMT_REF_ARY))); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, nFormat ))); nFormat = FMT_REF_NUMBER_FULL_CONTEXT_IDX + 2 * SAL_N_ELEMENTS(FMT_REF_ARY); nPos = m_pFormatLB->InsertEntry(SwResId(FMT_REF_WITH_UPPERCASE_HU_ARTICLE) + GetFieldMgr().GetFormatStr( nTypeId, nFormat % SAL_N_ELEMENTS(FMT_REF_ARY))); m_pFormatLB->SetEntryData( nPos, reinterpret_cast(GetFieldMgr().GetFormatId( nTypeId, nFormat ))); nExtraSize += 3; } } nSize += nExtraSize; // select a certain entry if (nSize) { if (!IsFieldEdit()) m_pFormatLB->SelectEntry(sOldSel); else m_pFormatLB->SelectEntry(SwResId(FMT_REF_ARY[GetCurField()->GetFormat() % SAL_N_ELEMENTS(FMT_REF_ARY)])); if (!m_pFormatLB->GetSelectedEntryCount()) { m_pFormatLB->SelectEntryPos(nFieldDlgFormatSel); if (!m_pFormatLB->GetSelectedEntryCount()) m_pFormatLB->SelectEntryPos(0); } } return nSize; } // Modify IMPL_LINK_NOARG(SwFieldRefPage, ModifyHdl, Edit&, void) { OUString aName(m_pNameED->GetText()); const bool bEmptyName = aName.isEmpty(); bool bEnable = true; sal_uInt16 nTypeId = static_cast(reinterpret_cast(m_pTypeLB->GetEntryData(GetTypeSel()))); if ((nTypeId == TYP_SETREFFLD && !GetFieldMgr().CanInsertRefMark(aName)) || (bEmptyName && (nTypeId == TYP_GETREFFLD || nTypeId == TYP_SETREFFLD || nTypeId == REFFLDFLAG_BOOKMARK))) bEnable = false; EnableInsert(bEnable); m_pSelectionLB->SelectEntry(aName); } bool SwFieldRefPage::FillItemSet(SfxItemSet* ) { bool bModified = false; sal_uInt16 nTypeId = static_cast(reinterpret_cast(m_pTypeLB->GetEntryData(GetTypeSel()))); sal_uInt16 nSubType = 0; const sal_Int32 nEntryPos = m_pFormatLB->GetSelectedEntryPos(); const sal_uLong nFormat = (nEntryPos == LISTBOX_ENTRY_NOTFOUND) ? 0 : reinterpret_cast(m_pFormatLB->GetEntryData(nEntryPos)); OUString aVal(m_pValueED->GetText()); OUString aName(m_pNameED->GetText()); switch(nTypeId) { case TYP_GETREFFLD: nSubType = REF_SETREFATTR; break; case TYP_SETREFFLD: { SwFieldType* pType = GetFieldMgr().GetFieldType(SwFieldIds::SetExp, aName); if(!pType) // Only insert when the name doesn't exist yet { m_pSelectionLB->InsertEntry(aName); m_pSelection->Enable(); } break; } } SwGetRefField* pRefField = static_cast(GetCurField()); if (REFFLDFLAG & nTypeId) { SwWrtShell *pSh = GetWrtShell(); if(!pSh) { pSh = ::GetActiveWrtShell(); } if (nTypeId == REFFLDFLAG_BOOKMARK) // text marks! { aName = m_pNameED->GetText(); nTypeId = TYP_GETREFFLD; nSubType = REF_BOOKMARK; } else if (REFFLDFLAG_FOOTNOTE == nTypeId) // footnotes { SwSeqFieldList aArr; SeqFieldLstElem aElem( m_pSelectionLB->GetSelectedEntry(), 0 ); size_t nPos = 0; nTypeId = TYP_GETREFFLD; nSubType = REF_FOOTNOTE; aName.clear(); if (pSh->GetSeqFootnoteList(aArr) && aArr.SeekEntry(aElem, &nPos)) { aVal = OUString::number( aArr[nPos].nSeqNo ); if (IsFieldEdit() && aArr[nPos].nSeqNo == pRefField->GetSeqNo()) bModified = true; // can happen with fields of which the references were deleted } else if (IsFieldEdit()) aVal = OUString::number( pRefField->GetSeqNo() ); } else if (REFFLDFLAG_ENDNOTE == nTypeId) // endnotes { SwSeqFieldList aArr; SeqFieldLstElem aElem( m_pSelectionLB->GetSelectedEntry(), 0 ); size_t nPos = 0; nTypeId = TYP_GETREFFLD; nSubType = REF_ENDNOTE; aName.clear(); if (pSh->GetSeqFootnoteList(aArr, true) && aArr.SeekEntry(aElem, &nPos)) { aVal = OUString::number( aArr[nPos].nSeqNo ); if (IsFieldEdit() && aArr[nPos].nSeqNo == pRefField->GetSeqNo()) bModified = true; // can happen with fields of which the reference was deleted } else if (IsFieldEdit()) aVal = OUString::number( pRefField->GetSeqNo() ); } // #i83479# else if ( nTypeId == REFFLDFLAG_HEADING ) { SvTreeListEntry* pEntry = m_pSelectionToolTipLB->GetCurEntry(); OSL_ENSURE( pEntry, " - no entry selected in selection tool tip listbox!" ); if ( pEntry ) { const size_t nOutlIdx( static_cast (reinterpret_cast(pEntry->GetUserData())) ); pSh->getIDocumentOutlineNodesAccess()->getOutlineNodes( maOutlineNodes ); if ( nOutlIdx < maOutlineNodes.size() ) { ::sw::mark::IMark const * const pMark = pSh->getIDocumentMarkAccess()->getMarkForTextNode( *(maOutlineNodes[nOutlIdx]), IDocumentMarkAccess::MarkType::CROSSREF_HEADING_BOOKMARK); aName = pMark->GetName(); nTypeId = TYP_GETREFFLD; nSubType = REF_BOOKMARK; } } } else if ( nTypeId == REFFLDFLAG_NUMITEM ) { SvTreeListEntry* pEntry = m_pSelectionToolTipLB->GetCurEntry(); OSL_ENSURE( pEntry, " - no entry selected in selection tool tip listbox!" ); if ( pEntry ) { const size_t nNumItemIdx( static_cast (reinterpret_cast(pEntry->GetUserData())) ); pSh->getIDocumentListItemsAccess()->getNumItems( maNumItems ); if ( nNumItemIdx < maNumItems.size() ) { ::sw::mark::IMark const * const pMark = pSh->getIDocumentMarkAccess()->getMarkForTextNode( *(maNumItems[nNumItemIdx]->GetTextNode()), IDocumentMarkAccess::MarkType::CROSSREF_NUMITEM_BOOKMARK); aName = pMark->GetName(); nTypeId = TYP_GETREFFLD; nSubType = REF_BOOKMARK; } } } else // SequenceFields { // get fields for Seq-FieldType: SwSetExpFieldType* pType = static_cast(pSh->GetFieldType( nTypeId & ~REFFLDFLAG, SwFieldIds::SetExp )); if( pType ) { SwSeqFieldList aArr; SeqFieldLstElem aElem( m_pSelectionLB->GetSelectedEntry(), 0 ); size_t nPos = 0; nTypeId = TYP_GETREFFLD; nSubType = REF_SEQUENCEFLD; aName = pType->GetName(); if (pType->GetSeqFieldList(aArr) && aArr.SeekEntry(aElem, &nPos)) { aVal = OUString::number( aArr[nPos].nSeqNo ); if (IsFieldEdit() && aArr[nPos].nSeqNo == pRefField->GetSeqNo()) bModified = true; // can happen with fields of which the reference was deleted } else if (IsFieldEdit()) aVal = OUString::number( pRefField->GetSeqNo() ); } } } if (IsFieldEdit() && nTypeId == TYP_GETREFFLD) { aVal = OUString::number(nSubType) + "|" + aVal; } if (!IsFieldEdit() || bModified || m_pNameED->IsValueChangedFromSaved() || m_pValueED->IsValueChangedFromSaved() || m_pTypeLB->IsValueChangedFromSaved() || m_pSelectionLB->IsValueChangedFromSaved() || m_pFormatLB->IsValueChangedFromSaved()) { InsertField( nTypeId, nSubType, aName, aVal, nFormat ); } ModifyHdl(*m_pNameED); // enable/disable insert if applicable return false; } VclPtr SwFieldRefPage::Create( TabPageParent pParent, const SfxItemSet *const pAttrSet) { return VclPtr::Create( pParent.pParent, pAttrSet ); } sal_uInt16 SwFieldRefPage::GetGroup() { return GRP_REF; } void SwFieldRefPage::FillUserData() { const sal_Int32 nEntryPos = m_pTypeLB->GetSelectedEntryPos(); const sal_uInt16 nTypeSel = ( LISTBOX_ENTRY_NOTFOUND == nEntryPos ) ? USHRT_MAX : sal::static_int_cast< sal_uInt16 > (reinterpret_cast< sal_uIntPtr >(m_pTypeLB->GetEntryData( nEntryPos ))); const sal_Int32 nFormatEntryPos = m_pFormatLB->GetSelectedEntryPos(); const sal_uInt32 nFormatSel = LISTBOX_ENTRY_NOTFOUND == nFormatEntryPos ? USHRT_MAX : nFormatEntryPos; SetUserData( USER_DATA_VERSION ";" + OUString::number( nTypeSel ) + ";" + OUString::number( nFormatSel )); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */