Files
libreoffice/sw/source/ui/fldui/fldpage.cxx

461 lines
14 KiB
C++

/*************************************************************************
*
* $RCSfile: fldpage.cxx,v $
*
* $Revision: 1.4 $
*
* last change: $Author: os $ $Date: 2001-06-08 13:47:31 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (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.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#ifdef PRECOMPILED
#include "ui_pch.hxx"
#endif
#pragma hdrstop
#ifndef _SV_LSTBOX_HXX //autogen
#include <vcl/lstbox.hxx>
#endif
#ifndef _SFXSTRITEM_HXX //autogen
#include <svtools/stritem.hxx>
#endif
#ifndef _SFXREQUEST_HXX //autogen
#include <sfx2/request.hxx>
#endif
#ifndef _SVX_HTMLMODE_HXX //autogen
#include <svx/htmlmode.hxx>
#endif
#ifndef _DBFLD_HXX //autogen
#include <dbfld.hxx>
#endif
#ifndef _FLDDAT_HXX
#include <flddat.hxx>
#endif
#ifndef _FMTFLD_HXX //autogen
#include <fmtfld.hxx>
#endif
#ifndef _VIEWOPT_HXX
#include <viewopt.hxx>
#endif
#ifndef _FLDEDT_HXX
#include <fldedt.hxx>
#endif
#ifndef _DOCSH_HXX
#include <docsh.hxx>
#endif
#ifndef _SWMODULE_HXX
#include <swmodule.hxx>
#endif
#ifndef _VIEW_HXX
#include <view.hxx>
#endif
#ifndef _WRTSH_HXX
#include <wrtsh.hxx>
#endif
#ifndef _EXPFLD_HXX
#include <expfld.hxx>
#endif
#ifndef _FLDTDLG_HXX
#include <fldtdlg.hxx>
#endif
#ifndef _FLDPAGE_HXX
#include <fldpage.hxx>
#endif
#ifndef _CMDID_H
#include <cmdid.h>
#endif
#ifndef _GLOBALS_HRC
#include <globals.hrc>
#endif
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
SwFldPage::SwFldPage(Window *pParent, const ResId &rId, const SfxItemSet &rAttrSet ) :
SfxTabPage (pParent, rId, rAttrSet),
nPageId (rId.GetId()),
bFldDlgHtmlMode (FALSE),
nFldDlgAktGrpSel(0),
nTypeSel (LISTBOX_ENTRY_NOTFOUND),
nSelectionSel (LISTBOX_ENTRY_NOTFOUND),
bFldEdit (FALSE),
pCurFld (0),
bInsert (TRUE),
bRefresh (FALSE)
{
// FreeResource();
}
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
SwFldPage::~SwFldPage()
{
}
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
USHORT SwFldPage::GetGroup()
{
ASSERT (0, "GetGroup not implemented!");
return 0;
}
/*--------------------------------------------------------------------
Beschreibung: TabPage initialisieren
--------------------------------------------------------------------*/
void SwFldPage::Init()
{
SwDocShell* pDocSh = (SwDocShell*)SfxObjectShell::Current();
BOOL bNewMode = (::GetHtmlMode(pDocSh) & HTMLMODE_ON) != 0;
bFldEdit = GetTabDialog() == 0;
pCurFld = aMgr.GetCurFld();
nFldDlgAktGrpSel = GetGroup();
if (bNewMode != bFldDlgHtmlMode)
{
bFldDlgHtmlMode = bNewMode;
// Bereichslistbox initialisieren
if (bFldDlgHtmlMode)
{
SwWrtShell *pSh = ::GetActiveView()->GetWrtShellPtr();
(SwSetExpFieldType*)pSh->InsertFldType(SwSetExpFieldType(pDocSh->GetDoc(),
String::CreateFromAscii("HTML_ON"), 1));
(SwSetExpFieldType*)pSh->InsertFldType(SwSetExpFieldType(pDocSh->GetDoc(),
String::CreateFromAscii("HTML_OFF"), 1));
}
}
aMgr.GetCurFld(); // FieldManager neu initialisieren
// wichtig fuer Dok-Wechsel (fldtdlg:ReInitTabPage)
}
/*--------------------------------------------------------------------
Beschreibung: Seite neu initialisieren
--------------------------------------------------------------------*/
void SwFldPage::ActivatePage()
{
EnableInsert(bInsert);
}
/*--------------------------------------------------------------------
Beschreibung: Kompletter Reset; neues Feld editieren
--------------------------------------------------------------------*/
void SwFldPage::EditNewField()
{
nFldDlgAktGrpSel = 0;
nTypeSel = LISTBOX_ENTRY_NOTFOUND;
nSelectionSel = LISTBOX_ENTRY_NOTFOUND;
bRefresh = TRUE;
Reset(*(SfxItemSet*)0);
bRefresh = FALSE;
}
/*--------------------------------------------------------------------
Beschreibung: Feld einfuegen
--------------------------------------------------------------------*/
BOOL SwFldPage::InsertFld(USHORT nTypeId, USHORT nSubType, const String& rPar1,
const String& rPar2, ULONG nFormatId, sal_Unicode cSeparator)
{
BOOL bRet = FALSE;
SwWrtShell *pSh = ::GetActiveView()->GetWrtShellPtr();
if (!IsFldEdit()) // Neues Feld einfuegen
{
SwInsertFld_Data aData(nTypeId, nSubType, rPar1, rPar2, nFormatId, 0, cSeparator );
bRet = aMgr.InsertFld( aData );
}
else // Feld aendern
{
String sPar1(rPar1);
String sPar2(rPar2);
BOOL bDBChanged = FALSE;
switch( nTypeId )
{
case TYP_DATEFLD:
case TYP_TIMEFLD:
nSubType = ((nTypeId == TYP_DATEFLD) ? DATEFLD : TIMEFLD) |
((nSubType == DATE_VAR) ? 0 : FIXEDFLD);
break;
case TYP_DBNAMEFLD:
case TYP_DBNEXTSETFLD:
case TYP_DBNUMSETFLD:
case TYP_DBSETNUMBERFLD:
{
USHORT nPos, nTablePos, nExpPos;
SwDBData aData;
// DBName aus rPar1 extrahieren. Format: DBName.TableName.ExpStrg
if ((nTablePos = rPar1.Search(DB_DELIM)) != STRING_NOTFOUND)
aData.sDataSource = rPar1.Copy(0, nTablePos++);
if ((nExpPos = rPar1.Search(DB_DELIM, nTablePos)) != STRING_NOTFOUND)
{
aData.sCommand = rPar1.Copy(nTablePos, nExpPos++ - nTablePos);
}
if (nExpPos != STRING_NOTFOUND)
nPos = nExpPos;
else if (nTablePos != STRING_NOTFOUND)
nPos = nTablePos;
else
nPos = 0;
sPar1 = rPar1.Copy(nPos);
((SwDBNameInfField*)pCurFld)->SetDBData(aData);
bDBChanged = TRUE;
}
break;
case TYP_DBFLD:
{
SwDBData aData;
aData.sDataSource = rPar1.GetToken(0, DB_DELIM);
aData.sCommand = rPar1.GetToken(1, DB_DELIM);
String sColumn = rPar1.GetToken(2, DB_DELIM);
SwDBFieldType* pOldTyp = (SwDBFieldType*)pCurFld->GetTyp();
SwDBFieldType* pTyp = (SwDBFieldType*)pSh->InsertFldType(
SwDBFieldType(pSh->GetDoc(), sColumn, aData));
SwClientIter aIter( *pOldTyp );
for( SwFmtFld* pFmtFld = (SwFmtFld*)aIter.First( TYPE(SwFmtFld) );
pFmtFld; pFmtFld = (SwFmtFld*)aIter.Next() )
{
if( pFmtFld->GetFld() == pCurFld)
{
pTyp->Add(pFmtFld); // Feld auf neuen Typ umhaengen
pCurFld->ChgTyp(pTyp);
break;
}
}
bDBChanged = TRUE;
}
break;
case TYP_SEQFLD:
{
SwSetExpFieldType* pTyp = (SwSetExpFieldType*)pCurFld->GetTyp();
pTyp->SetOutlineLvl(nSubType & 0xff);
pTyp->SetDelimiter(cSeparator);
nSubType = GSE_SEQ;
}
break;
case TYP_INPUTFLD:
{
// User- oder SetField ?
if (aMgr.GetFldType(RES_USERFLD, sPar1) == 0 &&
!(pCurFld->GetSubType() & INP_TXT)) // SETEXPFLD
{
SwSetExpField* pFld = (SwSetExpField*)pCurFld;
pFld->SetPromptText(sPar2);
sPar2 = pFld->GetPar2();
}
}
break;
}
pSh->StartAllAction();
pCurFld->SetSubType(nSubType);
aMgr.UpdateCurFld( nFormatId, sPar1, sPar2 );
switch (nTypeId)
{
case TYP_HIDDENTXTFLD:
case TYP_HIDDENPARAFLD:
aMgr.EvalExpFlds(pSh);
break;
}
if (bDBChanged) // Datenbank geaendert
{
switch(nTypeId)
{
case TYP_DBFLD:
((SwDBField*)pCurFld)->ClearInitialized();
((SwDBField*)pCurFld)->InitContent();
case TYP_DBNAMEFLD:
case TYP_DBNEXTSETFLD:
case TYP_DBNUMSETFLD:
case TYP_DBSETNUMBERFLD:
pCurFld->GetTyp()->UpdateFlds();
break;
}
}
pSh->SetUndoNoResetModified();
pSh->EndAllAction();
}
return bRet;
}
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
void SwFldPage::SavePos(ListBox* pLst1, ListBox* pLst2, ListBox* pLst3)
{
if (pLst1 && pLst1->GetEntryCount())
sLst1 = pLst1->GetSelectEntry();
else
sLst1.Erase();
if (pLst2 && pLst2->GetEntryCount())
sLst2 = pLst2->GetSelectEntry();
else
sLst2.Erase();
if (pLst3 && pLst3->GetEntryCount())
sLst3 = pLst3->GetSelectEntry();
else
sLst3.Erase();
}
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
void SwFldPage::RestorePos(ListBox* pLst1, ListBox* pLst2, ListBox* pLst3)
{
USHORT nPos = 0;
if (pLst1 && pLst1->GetEntryCount() && sLst1.Len() && (nPos = pLst1->GetEntryPos(sLst1)) != LISTBOX_ENTRY_NOTFOUND)
pLst1->SelectEntryPos(nPos);
if (pLst2 && pLst2->GetEntryCount() && sLst1.Len() && (nPos = pLst2->GetEntryPos(sLst1)) != LISTBOX_ENTRY_NOTFOUND)
pLst2->SelectEntryPos(nPos);
if (pLst3 && pLst3->GetEntryCount() && sLst1.Len() && (nPos = pLst3->GetEntryPos(sLst1)) != LISTBOX_ENTRY_NOTFOUND)
pLst3->SelectEntryPos(nPos);
}
/*--------------------------------------------------------------------
Beschreibung: Einfuegen von neuen Feldern
--------------------------------------------------------------------*/
IMPL_LINK( SwFldPage, InsertHdl, Button *, pBtn )
{
SwFldDlg *pDlg = (SwFldDlg*)GetTabDialog();
if (pDlg)
{
pDlg->InsertHdl();
if (pBtn)
pBtn->GrabFocus(); // Wegen InputField-Dlg
}
else
{
SwFldEditDlg *pEditDlg = (SwFldEditDlg *)GetParent();
pEditDlg->InsertHdl();
}
return 0;
}
/*--------------------------------------------------------------------
Beschreibung: "Einfuegen"-Button Enablen/Disablen
--------------------------------------------------------------------*/
void SwFldPage::EnableInsert(BOOL bEnable)
{
SwFldDlg *pDlg = (SwFldDlg*)GetTabDialog();
if (pDlg)
{
if (pDlg->GetCurPageId() == nPageId)
pDlg->EnableInsert(bEnable);
}
else
{
SwFldEditDlg *pEditDlg = (SwFldEditDlg *)GetParent();
pEditDlg->EnableInsert(bEnable);
}
bInsert = bEnable;
}
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
IMPL_LINK( SwFldPage, NumFormatHdl, ListBox *, pLst )
{
InsertHdl();
return 0;
}