/* -*- 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 typedef ::std::vector< Window* > ImplMoreWindowList; struct ImplMoreButtonData { ImplMoreWindowList *mpItemList; OUString maMoreText; OUString maLessText; }; void MoreButton::ImplInit( Window* pParent, WinBits nStyle ) { mpMBData = new ImplMoreButtonData; mnDelta = 0; meUnit = MAP_PIXEL; mbState = sal_False; mpMBData->mpItemList = NULL; PushButton::ImplInit( pParent, nStyle ); mpMBData->maMoreText = Button::GetStandardText( BUTTON_MORE ); mpMBData->maLessText = Button::GetStandardText( BUTTON_LESS ); SetHelpText( Button::GetStandardHelpText( BUTTON_MORE ) ); ShowState(); SetSymbolAlign(SYMBOLALIGN_RIGHT); SetImageAlign(IMAGEALIGN_RIGHT); //Resoves: fdo#31849 ensure button remains vertically centered SetSmallSymbol(true); if ( ! ( nStyle & ( WB_RIGHT | WB_LEFT ) ) ) { nStyle |= WB_CENTER; SetStyle( nStyle ); } } void MoreButton::ShowState() { if ( mbState ) { SetSymbol( SYMBOL_PAGEUP ); SetText( mpMBData->maLessText ); } else { SetSymbol( SYMBOL_PAGEDOWN ); SetText( mpMBData->maMoreText ); } } MoreButton::MoreButton( Window* pParent, WinBits nStyle ) : PushButton( WINDOW_MOREBUTTON ) { ImplInit( pParent, nStyle ); } MoreButton::MoreButton( Window* pParent, const ResId& rResId ) : PushButton( WINDOW_MOREBUTTON ) { rResId.SetRT( RSC_MOREBUTTON ); WinBits nStyle = ImplInitRes( rResId ); ImplInit( pParent, nStyle ); ImplLoadRes( rResId ); if ( !(nStyle & WB_HIDE) ) Show(); } void MoreButton::ImplLoadRes( const ResId& rResId ) { PushButton::ImplLoadRes( rResId ); sal_uLong nObjMask = ReadLongRes(); if ( nObjMask & RSC_MOREBUTTON_STATE ) { // Don't call method as Dialog should not be switched over mbState = (sal_Bool)ReadShortRes(); // SetText( GetText() ); ShowState(); } if ( nObjMask & RSC_MOREBUTTON_MAPUNIT ) meUnit = (MapUnit)ReadLongRes(); if ( nObjMask & RSC_MOREBUTTON_DELTA ) // Size for resizing the Dialog mnDelta = ReadShortRes(); } MoreButton::~MoreButton() { if ( mpMBData->mpItemList ) delete mpMBData->mpItemList; delete mpMBData; } void MoreButton::Click() { Window* pParent = GetParent(); Size aSize( pParent->GetSizePixel() ); long nDeltaPixel = LogicToPixel( Size( 0, mnDelta ), meUnit ).Height(); // Change status mbState = !mbState; ShowState(); // Call Click handler here, so that we can initialize the Controls PushButton::Click(); // Update the windows according to the status if ( mbState ) { // Show window if ( mpMBData->mpItemList ) { for ( size_t i = 0, n = mpMBData->mpItemList->size(); i < n; ++i ) { (*mpMBData->mpItemList)[ i ]->Show(); } } // Adapt dialogbox Point aPos( pParent->GetPosPixel() ); Rectangle aDeskRect( pParent->ImplGetFrameWindow()->GetDesktopRectPixel() ); aSize.Height() += nDeltaPixel; if ( (aPos.Y()+aSize.Height()) > aDeskRect.Bottom() ) { aPos.Y() = aDeskRect.Bottom()-aSize.Height(); if ( aPos.Y() < aDeskRect.Top() ) aPos.Y() = aDeskRect.Top(); pParent->SetPosSizePixel( aPos, aSize ); } else pParent->SetSizePixel( aSize ); } else { // Adapt Dialogbox aSize.Height() -= nDeltaPixel; pParent->SetSizePixel( aSize ); // Hide window(s) again if ( mpMBData->mpItemList ) { for ( size_t i = 0, n = mpMBData->mpItemList->size(); i < n; ++i ) { (*mpMBData->mpItemList)[ i ]->Hide(); } } } } void MoreButton::AddWindow( Window* pWindow ) { if ( !mpMBData->mpItemList ) mpMBData->mpItemList = new ImplMoreWindowList(); mpMBData->mpItemList->push_back( pWindow ); if ( mbState ) pWindow->Show(); else pWindow->Hide(); } void MoreButton::SetText( const OUString& rText ) { PushButton::SetText( rText ); } OUString MoreButton::GetText() const { return PushButton::GetText(); } void MoreButton::SetMoreText( const OUString& rText ) { if ( mpMBData ) mpMBData->maMoreText = rText; if ( !mbState ) SetText( rText ); } OUString MoreButton::GetMoreText() const { if ( mpMBData ) return mpMBData->maMoreText; else return PushButton::GetText(); } void MoreButton::SetLessText( const OUString& rText ) { if ( mpMBData ) mpMBData->maLessText = rText; if ( mbState ) SetText( rText ); } OUString MoreButton::GetLessText() const { if ( mpMBData ) return mpMBData->maLessText; else return PushButton::GetText(); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */