Files
libreoffice/svx/source/dialog/langbox.cxx

463 lines
15 KiB
C++
Raw Normal View History

2000-09-18 16:07:07 +00:00
/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 16:07:07 +00:00
*
* $RCSfile: langbox.cxx,v $
2000-09-18 16:07:07 +00:00
*
* $Revision: 1.15 $
2000-09-18 16:07:07 +00:00
*
* last change: $Author: rt $ $Date: 2005-09-08 21:25:16 $
2000-09-18 16:07:07 +00:00
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
2000-09-18 16:07:07 +00:00
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
2000-09-18 16:07:07 +00:00
*
* 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.
2000-09-18 16:07:07 +00:00
*
* 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.
2000-09-18 16:07:07 +00:00
*
* 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
2000-09-18 16:07:07 +00:00
*
************************************************************************/
// include ---------------------------------------------------------------
#ifndef _COM_SUN_STAR_LINGUISTIC2_XLINGUSERVICEMANAGER_HDL_
#include <com/sun/star/linguistic2/XLinguServiceManager.hdl>
#endif
#ifndef _COM_SUN_STAR_LINGUISTIC2_XAVAILABLELOCALES_HPP_
#include <com/sun/star/linguistic2/XAvailableLocales.hpp>
#endif
#ifndef _LINGUISTIC_MISC_HXX_
#include <linguistic/misc.hxx>
#endif
#ifndef _RTL_USTRING_HXX_
#include<rtl/ustring.hxx>
#endif
#ifndef _UNOTOOLS_LOCALEDATAWRAPPER_HXX
#include <unotools/localedatawrapper.hxx>
#endif
#ifndef _SHL_HXX
#include <tools/shl.hxx>
#endif
#ifndef _ISOLANG_HXX
#include <tools/isolang.hxx>
#endif
2000-09-18 16:07:07 +00:00
#pragma hdrstop
#ifndef _SVX_SCRIPTTYPEITEM_HXX
#include <scripttypeitem.hxx>
#endif
#ifndef _UNO_LINGU_HXX
#include <unolingu.hxx>
#endif
#ifndef _SVX_LANGTAB_HXX
#include <langtab.hxx>
#endif
2000-09-18 16:07:07 +00:00
#include "langbox.hxx"
#include "langtab.hxx"
#include "dialmgr.hxx"
#include "dialogs.hrc"
#include "unolingu.hxx"
using namespace ::rtl;
using namespace ::com::sun::star::util;
using namespace ::com::sun::star::lang;
using namespace ::com::sun::star::linguistic2;
using namespace ::com::sun::star::uno;
#define A2OU(x) OUString::createFromAscii( x )
//========================================================================
// list of languages for forbidden chars
//========================================================================
static const LanguageType aForbiddenCharLang[] =
{
LANGUAGE_CHINESE_TRADITIONAL,
LANGUAGE_CHINESE_SIMPLIFIED,
LANGUAGE_JAPANESE,
LANGUAGE_KOREAN,
LANGUAGE_USER_KOREAN_NORTH
};
static const int nForbiddenCharLang = sizeof( aForbiddenCharLang ) / sizeof( aForbiddenCharLang[0] );
static BOOL lcl_HasLanguage( const LanguageType *pLang, int nCount, LanguageType nLang )
{
int i = -1;
if (pLang && nCount > 0)
{
for (i = 0; i < nCount; ++i )
{
if (pLang[i] == nLang)
break;
}
}
return i >= 0 && i < nCount;
}
//========================================================================
// misc local helper functions
//========================================================================
static Sequence< INT16 > lcl_LocaleSeqToLangSeq( Sequence< Locale > &rSeq )
{
const Locale *pLocale = rSeq.getConstArray();
INT32 nCount = rSeq.getLength();
Sequence< INT16 > aLangs( nCount );
INT16 *pLang = aLangs.getArray();
for (INT32 i = 0; i < nCount; ++i)
{
pLang[i] = SvxLocaleToLanguage( pLocale[i] );
}
return aLangs;
}
static BOOL lcl_SeqHasLang( const Sequence< INT16 > & rLangSeq, INT16 nLang )
{
INT32 i = -1;
INT32 nLen = rLangSeq.getLength();
if (nLen)
{
const INT16 *pLang = rLangSeq.getConstArray();
for (i = 0; i < nLen; ++i)
{
if (nLang == pLang[i])
break;
}
}
return i >= 0 && i < nLen;
}
2000-09-18 16:07:07 +00:00
//========================================================================
// class SvxLanguageBox
//========================================================================
USHORT TypeToPos_Impl( LanguageType eType, const ListBox& rLb )
{
USHORT nPos = LISTBOX_ENTRY_NOTFOUND;
USHORT nCount = rLb.GetEntryCount();
for ( USHORT i=0; nPos == LISTBOX_ENTRY_NOTFOUND && i<nCount; i++ )
if ( eType == LanguageType((ULONG)rLb.GetEntryData(i)) )
nPos = i;
return nPos;
}
//-----------------------------------------------------------------------
2001-04-18 07:50:38 +00:00
SvxLanguageBox::SvxLanguageBox( Window* pParent, WinBits nWinStyle, BOOL bCheck ) :
ListBox( pParent, nWinStyle ),
m_pSpellUsedLang( NULL ),
2001-04-18 07:50:38 +00:00
m_bWithCheckmark( bCheck )
2000-09-18 16:07:07 +00:00
{
2001-04-18 07:50:38 +00:00
Init();
2000-09-18 16:07:07 +00:00
}
//------------------------------------------------------------------------
SvxLanguageBox::SvxLanguageBox( Window* pParent, const ResId& rResId, BOOL bCheck ) :
ListBox( pParent, rResId ),
m_pSpellUsedLang( NULL ),
m_bWithCheckmark( bCheck )
2001-04-18 07:50:38 +00:00
{
Init();
}
//------------------------------------------------------------------------
void SvxLanguageBox::Init()
2000-09-18 16:07:07 +00:00
{
m_pLangTable = new SvxLanguageTable;
m_aNotCheckedImage = Image( SVX_RES( RID_SVXIMG_NOTCHECKED ) );
m_aCheckedImage = Image( SVX_RES( RID_SVXIMG_CHECKED ) );
2002-07-19 09:07:02 +00:00
m_aCheckedImageHC = Image( SVX_RES( RID_SVXIMG_CHECKED_H ) );
m_aAllString = String( SVX_RESSTR( RID_SVXSTR_LANGUAGE_ALL ) );
m_nLangList = LANG_LIST_EMPTY;
m_bHasLangNone = FALSE;
m_bLangNoneIsLangAll = FALSE;
// display entries sorted
SetStyle( GetStyle() | WB_SORT );
if ( m_bWithCheckmark )
{
SvxLanguageTable aLangTable;
const USHORT nCount = aLangTable.GetEntryCount();
for ( USHORT i = 0; i < nCount; i++ )
{
LanguageType nLangType = aLangTable.GetTypeAtIndex( i );
BOOL bInsert = TRUE;
if ((LANGUAGE_DONTKNOW == nLangType) ||
(LANGUAGE_SYSTEM == nLangType) ||
(LANGUAGE_USER1 <= nLangType && nLangType <= LANGUAGE_USER9))
{
bInsert = FALSE;
}
if ( bInsert )
InsertLanguage( nLangType );
}
m_nLangList = LANG_LIST_ALL;
}
2000-09-18 16:07:07 +00:00
}
//------------------------------------------------------------------------
2000-09-18 16:07:07 +00:00
SvxLanguageBox::~SvxLanguageBox()
{
delete m_pSpellUsedLang;
delete m_pLangTable;
2000-09-18 16:07:07 +00:00
}
//------------------------------------------------------------------------
2002-07-19 09:07:02 +00:00
USHORT SvxLanguageBox::ImplInsertImgEntry( const String& rEntry, USHORT nPos, bool bChecked )
{
USHORT nRet = 0;
if( !bChecked )
nRet = InsertEntry( rEntry, m_aNotCheckedImage, nPos );
else if( GetSettings().GetStyleSettings().GetFaceColor().IsDark() )
nRet = InsertEntry( rEntry, m_aCheckedImageHC, nPos );
else
nRet = InsertEntry( rEntry, m_aCheckedImage, nPos );
return nRet;
}
//------------------------------------------------------------------------
void SvxLanguageBox::SetLanguageList( INT16 nLangList,
BOOL bHasLangNone, BOOL bLangNoneIsLangAll, BOOL bCheckSpellAvail )
{
Clear();
m_nLangList = nLangList;
m_bHasLangNone = bHasLangNone;
m_bLangNoneIsLangAll = bLangNoneIsLangAll;
m_bWithCheckmark = bCheckSpellAvail;
if ( LANG_LIST_EMPTY != nLangList )
{
Sequence< INT16 > aSpellAvailLang;
Sequence< INT16 > aHyphAvailLang;
Sequence< INT16 > aThesAvailLang;
Sequence< INT16 > aSpellUsedLang;
Sequence< INT16 > aHyphUsedLang;
Sequence< INT16 > aThesUsedLang;
Reference< XAvailableLocales > xAvail( LinguMgr::GetLngSvcMgr(), UNO_QUERY );
if (xAvail.is())
{
Sequence< Locale > aTmp;
if (LANG_LIST_SPELL_AVAIL & nLangList)
{
aTmp = xAvail->getAvailableLocales( A2OU( SN_SPELLCHECKER ) );
aSpellAvailLang = lcl_LocaleSeqToLangSeq( aTmp );
}
if (LANG_LIST_HYPH_AVAIL & nLangList)
{
aTmp = xAvail->getAvailableLocales( A2OU( SN_HYPHENATOR ) );
aHyphAvailLang = lcl_LocaleSeqToLangSeq( aTmp );
}
if (LANG_LIST_THES_AVAIL & nLangList)
{
aTmp = xAvail->getAvailableLocales( A2OU( SN_THESAURUS ) );
aThesAvailLang = lcl_LocaleSeqToLangSeq( aTmp );
}
}
if (LANG_LIST_SPELL_USED & nLangList)
{
Reference< XSpellChecker1 > xTmp1( SvxGetSpellChecker(), UNO_QUERY );
if (xTmp1.is())
aSpellUsedLang = xTmp1->getLanguages();
}
if (LANG_LIST_HYPH_USED & nLangList)
{
Reference< XHyphenator > xTmp( SvxGetHyphenator() );
2001-10-12 12:00:07 +00:00
if (xTmp.is()) {
Sequence < Locale > aLocaleSequence( xTmp->getLocales() );
aHyphUsedLang = lcl_LocaleSeqToLangSeq( aLocaleSequence );
}
}
if (LANG_LIST_THES_USED & nLangList)
{
Reference< XThesaurus > xTmp( SvxGetThesaurus() );
2001-10-12 12:00:07 +00:00
if (xTmp.is()) {
Sequence < Locale > aLocaleSequence( xTmp->getLocales() );
aThesUsedLang = lcl_LocaleSeqToLangSeq( aLocaleSequence );
}
}
SvxLanguageTable aLangTable;
::com::sun::star::uno::Sequence< sal_uInt16 > xKnown;
const sal_uInt16* pKnown;
USHORT nCount;
if ( nLangList & LANG_LIST_ONLY_KNOWN )
{
xKnown = LocaleDataWrapper::getInstalledLanguageTypes();
pKnown = xKnown.getConstArray();
nCount = (USHORT) xKnown.getLength();
}
else
{
nCount = aLangTable.GetEntryCount();
pKnown = NULL;
}
for ( USHORT i = 0; i < nCount; i++ )
{
LanguageType nLangType;
if ( nLangList & LANG_LIST_ONLY_KNOWN )
nLangType = pKnown[i];
else
nLangType = aLangTable.GetTypeAtIndex( i );
BOOL bInsert = FALSE;
2001-03-22 08:30:28 +00:00
if ( nLangType != LANGUAGE_DONTKNOW &&
nLangType != LANGUAGE_SYSTEM &&
nLangType != LANGUAGE_NONE &&
!(LANGUAGE_USER1 <= nLangType && nLangType <= LANGUAGE_USER9) )
{
if (!bInsert && (nLangList & LANG_LIST_ALL))
bInsert |= TRUE;
if (!bInsert && (nLangList & LANG_LIST_WESTERN))
bInsert |= SCRIPTTYPE_LATIN == SvtLanguageOptions::GetScriptTypeOfLanguage( nLangType );
if (!bInsert && (nLangList & LANG_LIST_CTL))
bInsert |= SCRIPTTYPE_COMPLEX == SvtLanguageOptions::GetScriptTypeOfLanguage( nLangType );
if (!bInsert && (nLangList & LANG_LIST_CJK))
bInsert |= SCRIPTTYPE_ASIAN == SvtLanguageOptions::GetScriptTypeOfLanguage( nLangType );
if (!bInsert && (nLangList & LANG_LIST_FBD_CHARS))
bInsert |= lcl_HasLanguage( aForbiddenCharLang,
nForbiddenCharLang, nLangType );
if (!bInsert && (nLangList & LANG_LIST_SPELL_AVAIL))
bInsert |= lcl_SeqHasLang( aSpellAvailLang, nLangType );
if (!bInsert && (nLangList & LANG_LIST_HYPH_AVAIL))
bInsert |= lcl_SeqHasLang( aHyphAvailLang, nLangType );
if (!bInsert && (nLangList & LANG_LIST_THES_AVAIL))
bInsert |= lcl_SeqHasLang( aThesAvailLang, nLangType );
if (!bInsert && (nLangList & LANG_LIST_SPELL_USED))
bInsert |= lcl_SeqHasLang( aSpellUsedLang, nLangType );
if (!bInsert && (nLangList & LANG_LIST_HYPH_USED))
bInsert |= lcl_SeqHasLang( aHyphUsedLang, nLangType );
if (!bInsert && (nLangList & LANG_LIST_THES_USED))
bInsert |= lcl_SeqHasLang( aThesUsedLang, nLangType );
}
if (bInsert)
InsertLanguage( nLangType );
}
if (bHasLangNone)
InsertLanguage( LANGUAGE_NONE );
}
}
//------------------------------------------------------------------------
USHORT SvxLanguageBox::InsertLanguage( const LanguageType nLangType, USHORT nPos )
2000-09-18 16:07:07 +00:00
{
String aStrEntry = m_pLangTable->GetString( nLangType );
if (LANGUAGE_NONE == nLangType && m_bHasLangNone && m_bLangNoneIsLangAll)
aStrEntry = m_aAllString;
USHORT nAt = 0;
if ( m_bWithCheckmark )
{
sal_Bool bFound = sal_False;
if (!m_pSpellUsedLang)
{
Reference< XSpellChecker1 > xSpell( SvxGetSpellChecker(), UNO_QUERY );
if ( xSpell.is() )
m_pSpellUsedLang = new Sequence< INT16 >( xSpell->getLanguages() );
}
bFound = m_pSpellUsedLang ?
lcl_SeqHasLang( *m_pSpellUsedLang, nLangType ) : FALSE;
2002-07-19 09:07:02 +00:00
nAt = ImplInsertImgEntry( aStrEntry, nPos, bFound );
}
else
nAt = InsertEntry( aStrEntry, nPos );
2000-09-18 16:07:07 +00:00
SetEntryData( nAt, (void*)(ULONG)nLangType );
2000-09-18 16:07:07 +00:00
return nPos;
}
//------------------------------------------------------------------------
USHORT SvxLanguageBox::InsertLanguage( const LanguageType nLangType,
BOOL bCheckEntry, USHORT nPos )
{
String aStrEntry = m_pLangTable->GetString( nLangType );
if (LANGUAGE_NONE == nLangType && m_bHasLangNone && m_bLangNoneIsLangAll)
aStrEntry = m_aAllString;
2002-07-19 09:07:02 +00:00
USHORT nAt = ImplInsertImgEntry( aStrEntry, nPos, bCheckEntry );
SetEntryData( nAt, (void*)(ULONG)nLangType );
return nPos;
}
//------------------------------------------------------------------------
2000-09-18 16:07:07 +00:00
void SvxLanguageBox::RemoveLanguage( const LanguageType eLangType )
{
USHORT nAt = TypeToPos_Impl( eLangType, *this );
if ( nAt != LISTBOX_ENTRY_NOTFOUND )
RemoveEntry( nAt );
}
//------------------------------------------------------------------------
LanguageType SvxLanguageBox::GetSelectLanguage() const
{
LanguageType eType = LanguageType(LANGUAGE_DONTKNOW);
USHORT nPos = GetSelectEntryPos();
if ( nPos != LISTBOX_ENTRY_NOTFOUND )
return LanguageType( (ULONG)GetEntryData(nPos) );
else
return LanguageType( LANGUAGE_DONTKNOW );
}
//------------------------------------------------------------------------
void SvxLanguageBox::SelectLanguage( const LanguageType eLangType, BOOL bSelect )
{
USHORT nAt = TypeToPos_Impl( eLangType, *this );
if ( nAt != LISTBOX_ENTRY_NOTFOUND )
SelectEntryPos( nAt, bSelect );
}
//------------------------------------------------------------------------
BOOL SvxLanguageBox::IsLanguageSelected( const LanguageType eLangType ) const
{
USHORT nAt = TypeToPos_Impl( eLangType, *this );
if ( nAt != LISTBOX_ENTRY_NOTFOUND )
return IsEntryPosSelected( nAt );
else
return FALSE;
}