diff options
Diffstat (limited to 'sd/source/ui/app/sdpopup.cxx')
-rw-r--r-- | sd/source/ui/app/sdpopup.cxx | 300 |
1 files changed, 300 insertions, 0 deletions
diff --git a/sd/source/ui/app/sdpopup.cxx b/sd/source/ui/app/sdpopup.cxx new file mode 100644 index 000000000..eeadaef35 --- /dev/null +++ b/sd/source/ui/app/sdpopup.cxx @@ -0,0 +1,300 @@ +/* -*- 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 <editeng/flditem.hxx> +#include <sfx2/objsh.hxx> +#include <sfx2/docfile.hxx> +#include <unotools/useroptions.hxx> + +#include <strings.hrc> +#include <sdpopup.hxx> +#include <sdresid.hxx> +#include <sdmod.hxx> +#include <DrawDocShell.hxx> + +/* + * Popup menu for editing of field command + */ +SdFieldPopup::SdFieldPopup( const SvxFieldData* pInField, LanguageType eLanguage ) : + PopupMenu (), + pField ( pInField ) +{ + Fill( eLanguage ); +} + +SdFieldPopup::~SdFieldPopup() +{ +} + +void SdFieldPopup::Fill( LanguageType eLanguage ) +{ + sal_uInt16 nID = 1; + MenuItemBits nStyle = MenuItemBits::RADIOCHECK | MenuItemBits::AUTOCHECK; + InsertItem( nID++, SdResId( STR_FIX ), nStyle ); + InsertItem( nID++, SdResId( STR_VAR ), nStyle ); + InsertSeparator(); + + if( dynamic_cast< const SvxDateField *>( pField ) != nullptr ) + { + const SvxDateField* pDateField = static_cast<const SvxDateField*>( pField ); + SvxDateField aDateField( *pDateField ); + + if( pDateField->GetType() == SvxDateType::Fix ) + CheckItem( 1 ); + else + CheckItem( 2 ); + + //SvxDateFormat::AppDefault, // is not used + //SvxDateFormat::System, // is not used + InsertItem( nID++, SdResId( STR_STANDARD_SMALL ), nStyle ); + InsertItem( nID++, SdResId( STR_STANDARD_BIG ), nStyle ); + + SvNumberFormatter* pNumberFormatter = SD_MOD()->GetNumberFormatter(); + aDateField.SetFormat( SvxDateFormat::A ); // 13.02.96 + InsertItem( nID++, aDateField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + aDateField.SetFormat( SvxDateFormat::B ); // 13.02.1996 + InsertItem( nID++, aDateField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + aDateField.SetFormat( SvxDateFormat::C ); // 13.Feb 1996 + InsertItem( nID++, aDateField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + + aDateField.SetFormat( SvxDateFormat::D ); // 13.Februar 1996 + InsertItem( nID++, aDateField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + aDateField.SetFormat( SvxDateFormat::E ); // Die, 13.Februar 1996 + InsertItem( nID++, aDateField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + aDateField.SetFormat( SvxDateFormat::F ); // Dienstag, 13.Februar 1996 + InsertItem( nID++, aDateField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + + CheckItem( static_cast<sal_uInt16>( pDateField->GetFormat() ) + 1 ); // - 2 + 3 ! + } + else if( dynamic_cast< const SvxExtTimeField *>( pField ) != nullptr ) + { + const SvxExtTimeField* pTimeField = static_cast<const SvxExtTimeField*>( pField ); + SvxExtTimeField aTimeField( *pTimeField ); + + if( pTimeField->GetType() == SvxTimeType::Fix ) + CheckItem( 1 ); + else + CheckItem( 2 ); + + //SvxTimeFormat::AppDefault, // is not used + //SvxTimeFormat::System, // is not used + InsertItem( nID++, SdResId( STR_STANDARD_NORMAL ), nStyle ); + + SvNumberFormatter* pNumberFormatter = SD_MOD()->GetNumberFormatter(); + aTimeField.SetFormat( SvxTimeFormat::HH24_MM ); // 13:49 + InsertItem( nID++, aTimeField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + aTimeField.SetFormat( SvxTimeFormat::HH24_MM_SS ); // 13:49:38 + InsertItem( nID++, aTimeField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + aTimeField.SetFormat( SvxTimeFormat::HH24_MM_SS_00 ); // 13:49:38.78 + InsertItem( nID++, aTimeField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + + aTimeField.SetFormat( SvxTimeFormat::HH12_MM ); // 01:49 + InsertItem( nID++, aTimeField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + aTimeField.SetFormat( SvxTimeFormat::HH12_MM_SS ); // 01:49:38 + InsertItem( nID++, aTimeField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + aTimeField.SetFormat( SvxTimeFormat::HH12_MM_SS_00 ); // 01:49:38.78 + InsertItem( nID++, aTimeField.GetFormatted( *pNumberFormatter, eLanguage ), nStyle ); + //SvxTimeFormat::HH12_MM_AMPM, // 01:49 PM + //SvxTimeFormat::HH12_MM_SS_AMPM, // 01:49:38 PM + //SvxTimeFormat::HH12_MM_SS_00_AMPM // 01:49:38.78 PM + + CheckItem( static_cast<sal_uInt16>( pTimeField->GetFormat() ) + 1 ); // - 2 + 3 ! + } + else if( dynamic_cast< const SvxExtFileField *>( pField ) != nullptr ) + { + const SvxExtFileField* pFileField = static_cast<const SvxExtFileField*>(pField); + //SvxExtFileField aFileField( *pFileField ); + + if( pFileField->GetType() == SvxFileType::Fix ) + CheckItem( 1 ); + else + CheckItem( 2 ); + + InsertItem( nID++, SdResId( STR_FILEFORMAT_NAME_EXT ), nStyle ); + InsertItem( nID++, SdResId( STR_FILEFORMAT_FULLPATH ), nStyle ); + InsertItem( nID++, SdResId( STR_FILEFORMAT_PATH ), nStyle ); + InsertItem( nID++, SdResId( STR_FILEFORMAT_NAME ), nStyle ); + + CheckItem( static_cast<sal_uInt16>( pFileField->GetFormat() ) + 3 ); + } + else if( dynamic_cast< const SvxAuthorField *>( pField ) != nullptr ) + { + const SvxAuthorField* pAuthorField = static_cast<const SvxAuthorField*>(pField); + SvxAuthorField aAuthorField( *pAuthorField ); + + if( pAuthorField->GetType() == SvxAuthorType::Fix ) + CheckItem( 1 ); + else + CheckItem( 2 ); + + for( sal_uInt16 i = 0; i < 4; i++ ) + { + aAuthorField.SetFormat( static_cast<SvxAuthorFormat>(i) ); + InsertItem( nID++, aAuthorField.GetFormatted(), nStyle ); + } + CheckItem( static_cast<sal_uInt16>( pAuthorField->GetFormat() ) + 3 ); + } +} + +/** + * Returns a new field, owned by caller. + * Returns NULL if nothing changed. + */ +SvxFieldData* SdFieldPopup::GetField() +{ + SvxFieldData* pNewField = nullptr; + sal_uInt16 nCount = GetItemCount(); + + if( dynamic_cast< const SvxDateField *>( pField ) != nullptr ) + { + const SvxDateField* pDateField = static_cast<const SvxDateField*>(pField); + SvxDateType eType; + SvxDateFormat eFormat; + sal_uInt16 i; + + if( IsItemChecked( 1 ) ) + eType = SvxDateType::Fix; + else + eType = SvxDateType::Var; + + for( i = 3; i <= nCount; i++ ) + { + if( IsItemChecked( i ) ) + break; + } + eFormat = static_cast<SvxDateFormat>( i - 1 ); + + if( pDateField->GetFormat() != eFormat || + pDateField->GetType() != eType ) + { + pNewField = new SvxDateField( *pDateField ); + static_cast<SvxDateField*>( pNewField )->SetType( eType ); + static_cast<SvxDateField*>( pNewField )->SetFormat( eFormat ); + + if( (pDateField->GetType() == SvxDateType::Var) && (eType == SvxDateType::Fix) ) + { + Date aDate( Date::SYSTEM ); + static_cast<SvxDateField*>( pNewField )->SetFixDate( aDate ); + } + } + } + else if( dynamic_cast< const SvxExtTimeField *>( pField ) != nullptr ) + { + const SvxExtTimeField* pTimeField = static_cast<const SvxExtTimeField*>(pField); + SvxTimeType eType; + SvxTimeFormat eFormat; + sal_uInt16 i; + + if( IsItemChecked( 1 ) ) + eType = SvxTimeType::Fix; + else + eType = SvxTimeType::Var; + + for( i = 3; i <= nCount; i++ ) + { + if( IsItemChecked( i ) ) + break; + } + eFormat = static_cast<SvxTimeFormat>( i - 1 ); + + if( pTimeField->GetFormat() != eFormat || + pTimeField->GetType() != eType ) + { + pNewField = new SvxExtTimeField( *pTimeField ); + static_cast<SvxExtTimeField*>( pNewField )->SetType( eType ); + static_cast<SvxExtTimeField*>( pNewField )->SetFormat( eFormat ); + + if( (pTimeField->GetType() == SvxTimeType::Var) && (eType == SvxTimeType::Fix) ) + { + tools::Time aTime( tools::Time::SYSTEM ); + static_cast<SvxExtTimeField*>( pNewField )->SetFixTime( aTime ); + } + + } + } + else if( dynamic_cast< const SvxExtFileField *>( pField ) != nullptr ) + { + const SvxExtFileField* pFileField = static_cast<const SvxExtFileField*>(pField); + SvxFileType eType; + SvxFileFormat eFormat; + sal_uInt16 i; + + if( IsItemChecked( 1 ) ) + eType = SvxFileType::Fix; + else + eType = SvxFileType::Var; + + for( i = 3; i <= nCount; i++ ) + { + if( IsItemChecked( i ) ) + break; + } + eFormat = static_cast<SvxFileFormat>( i - 3 ); + + if( pFileField->GetFormat() != eFormat || + pFileField->GetType() != eType ) + { + ::sd::DrawDocShell* pDocSh = dynamic_cast<::sd::DrawDocShell* >( SfxObjectShell::Current() ); + + if( pDocSh ) + { + OUString aName; + if( pDocSh->HasName() ) + aName = pDocSh->GetMedium()->GetName(); + + // Get current filename, not the one stored in the old field + pNewField = new SvxExtFileField( aName ); + static_cast<SvxExtFileField*>( pNewField )->SetType( eType ); + static_cast<SvxExtFileField*>( pNewField )->SetFormat( eFormat ); + } + } + } + else if( dynamic_cast< const SvxAuthorField *>( pField ) != nullptr ) + { + const SvxAuthorField* pAuthorField = static_cast<const SvxAuthorField*>(pField); + SvxAuthorType eType; + SvxAuthorFormat eFormat; + sal_uInt16 i; + + if( IsItemChecked( 1 ) ) + eType = SvxAuthorType::Fix; + else + eType = SvxAuthorType::Var; + + for( i = 3; i <= nCount; i++ ) + { + if( IsItemChecked( i ) ) + break; + } + eFormat = static_cast<SvxAuthorFormat>( i - 3 ); + + if( pAuthorField->GetFormat() != eFormat || + pAuthorField->GetType() != eType ) + { + // Get current state of address, not the old one + SvtUserOptions aUserOptions; + pNewField = new SvxAuthorField( aUserOptions.GetFirstName(), aUserOptions.GetLastName(), aUserOptions.GetID() ); + static_cast<SvxAuthorField*>( pNewField )->SetType( eType ); + static_cast<SvxAuthorField*>( pNewField )->SetFormat( eFormat ); + } + } + return pNewField; +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |