/* -*- 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 "FieldDescControl.hxx" #include "FieldControls.hxx" #include #include "TableDesignHelpBar.hxx" #include #include #include #include #include #include #include "FieldDescriptions.hxx" #include "dlgattr.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "QEnumTypes.hxx" #include "dbaccess_helpid.hrc" #include #include #include #include #include "UITools.hxx" #include "dbu_control.hrc" #include "dbu_tbl.hrc" #include using namespace dbaui; using namespace dbtools; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::beans; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::sdbc; using namespace ::com::sun::star::util; // For the Controls on the OFieldDescGenPage #define CONTROL_SPACING_X 18 // 6 #define CONTROL_SPACING_Y 4 #define CONTROL_WIDTH_1 160 // 100 #define CONTROL_WIDTH_2 100 // 60 #define CONTROL_WIDTH_3 250 #define CONTROL_WIDTH_4 (CONTROL_WIDTH_3 - 20 - 5) #define HSCROLL_STEP 20 namespace { template< typename T1, typename T2> void lcl_HideAndDeleteControl(short& _nPos,VclPtr& _pControl, VclPtr& _pControlText) { if ( _pControl ) { --_nPos; _pControl->Hide(); _pControlText->Hide(); _pControl.disposeAndClear(); _pControlText.disposeAndClear(); } } } // class OFieldDescControl OFieldDescControl::OFieldDescControl( vcl::Window* pParent, OTableDesignHelpBar* pHelpBar ) :TabPage( pParent, WB_3DLOOK | WB_DIALOGCONTROL ) ,pHelp( pHelpBar ) ,pLastFocusWindow(nullptr) ,m_pActFocusWindow(nullptr) ,pDefaultText(nullptr) ,pRequiredText(nullptr) ,pAutoIncrementText(nullptr) ,pTextLenText(nullptr) ,pNumTypeText(nullptr) ,pLengthText(nullptr) ,pScaleText(nullptr) ,pFormatText(nullptr) ,pBoolDefaultText(nullptr) ,m_pColumnNameText(nullptr) ,m_pTypeText(nullptr) ,m_pAutoIncrementValueText(nullptr) ,pRequired(nullptr) ,pNumType(nullptr) ,pAutoIncrement(nullptr) ,pDefault(nullptr) ,pTextLen(nullptr) ,pLength(nullptr) ,pScale(nullptr) ,pFormatSample(nullptr) ,pBoolDefault(nullptr) ,m_pColumnName(nullptr) ,m_pType(nullptr) ,m_pAutoIncrementValue(nullptr) ,pFormat(nullptr) ,m_pVertScroll( nullptr ) ,m_pHorzScroll( nullptr ) ,m_pPreviousType() ,m_nPos(-1) ,aYes(ModuleRes(STR_VALUE_YES)) ,aNo(ModuleRes(STR_VALUE_NO)) ,m_nOldVThumb( 0 ) ,m_nOldHThumb( 0 ) ,m_nWidth(50) ,m_bAdded(false) ,m_bRightAligned(false) ,pActFieldDescr(nullptr) { Contruct(); } void OFieldDescControl::Contruct() { m_pVertScroll = VclPtr::Create(this, WB_VSCROLL | WB_REPEAT | WB_DRAG); m_pHorzScroll = VclPtr::Create(this, WB_HSCROLL | WB_REPEAT | WB_DRAG); m_pVertScroll->SetScrollHdl(LINK(this, OFieldDescControl, OnScroll)); m_pHorzScroll->SetScrollHdl(LINK(this, OFieldDescControl, OnScroll)); m_pVertScroll->Show(); m_pHorzScroll->Show(); m_pVertScroll->EnableClipSiblings(); m_pHorzScroll->EnableClipSiblings(); m_pVertScroll->SetLineSize(1); m_pVertScroll->SetPageSize(1); m_pHorzScroll->SetLineSize(1); m_pHorzScroll->SetPageSize(1); m_nOldVThumb = m_nOldHThumb = 0; } OFieldDescControl::~OFieldDescControl() { disposeOnce(); } void OFieldDescControl::dispose() { if ( m_bAdded ) ::dbaui::notifySystemWindow(this,this,::comphelper::mem_fun(&TaskPaneList::RemoveWindow)); // Destroy children DeactivateAggregate( tpDefault ); DeactivateAggregate( tpRequired ); DeactivateAggregate( tpTextLen ); DeactivateAggregate( tpNumType ); DeactivateAggregate( tpScale ); DeactivateAggregate( tpLength ); DeactivateAggregate( tpFormat ); DeactivateAggregate( tpAutoIncrement ); DeactivateAggregate( tpBoolDefault ); DeactivateAggregate( tpColumnName ); DeactivateAggregate( tpType ); DeactivateAggregate( tpAutoIncrementValue ); pHelp.clear(); pLastFocusWindow.clear(); m_pActFocusWindow.clear(); pDefaultText.clear(); pRequiredText.clear(); pAutoIncrementText.clear(); pTextLenText.clear(); pNumTypeText.clear(); pLengthText.clear(); pScaleText.clear(); pFormatText.clear(); pBoolDefaultText.clear(); m_pColumnNameText.clear(); m_pTypeText.clear(); m_pAutoIncrementValueText.clear(); pRequired.clear(); pNumType.clear(); pAutoIncrement.clear(); pDefault.clear(); pTextLen.clear(); pLength.clear(); pScale.clear(); pFormatSample.clear(); pBoolDefault.clear(); m_pColumnName.clear(); m_pType.clear(); m_pAutoIncrementValue.clear(); pFormat.clear(); m_pVertScroll.disposeAndClear(); m_pHorzScroll.disposeAndClear(); TabPage::dispose(); } OUString OFieldDescControl::BoolStringPersistent(const OUString& rUIString) const { if (rUIString == aNo) return OUString('0'); if (rUIString == aYes) return OUString('1'); return OUString(); } OUString OFieldDescControl::BoolStringUI(const OUString& rPersistentString) const { // Older versions may store a language dependent string as a default if (rPersistentString == aYes || rPersistentString == aNo) return rPersistentString; if (rPersistentString == "0") return aNo; if (rPersistentString == "1") return aYes; return ModuleRes(STR_VALUE_NONE).toString(); } void OFieldDescControl::Init() { Reference< css::util::XNumberFormatter > xFormatter = GetFormatter(); ::dbaui::setEvalDateFormatForFormatter(xFormatter); } IMPL_LINK(OFieldDescControl, OnScroll, ScrollBar*, /*pBar*/, void) { ScrollAllAggregates(); } namespace { void getMaxXPosition(vcl::Window* _pWindow,long& _rnMaxXPosition) { if (_pWindow) { long nTemp = _pWindow->GetSizePixel().Width() + _pWindow->GetPosPixel().X(); _rnMaxXPosition = ::std::max(_rnMaxXPosition, nTemp); } } } void OFieldDescControl::CheckScrollBars() { // Calculate the ScrollBars' new position Size szOverallSize = GetSizePixel(); long nHScrollHeight = m_pHorzScroll->GetSizePixel().Height(); long nVScrollWidth = m_pVertScroll->GetSizePixel().Width(); long nNewHWidth = szOverallSize.Width() - nVScrollWidth; long nNewVHeight = szOverallSize.Height() - nHScrollHeight; bool bNeedHScrollBar(false), bNeedVScrollBar(false); // Adjust the areas // Do I actually need ScrollBars? // horizontal : long lMaxXPosition = 0; Control* ppAggregates[] = { pRequired, pNumType, pAutoIncrement, pDefault, pTextLen, pLength, pScale, pFormat, m_pColumnName, m_pType,m_pAutoIncrementValue}; for (Control* ppAggregate : ppAggregates) getMaxXPosition(ppAggregate,lMaxXPosition); lMaxXPosition += m_pHorzScroll->GetThumbPos() * HSCROLL_STEP; long lMaxXAvailable = szOverallSize.Width(); bNeedHScrollBar = lMaxXPosition > lMaxXAvailable; // Might change // Vertical // How many Controls do I have? sal_uInt16 nActive = CountActiveAggregates(); // Which one is the last one that fits? sal_uInt16 nLastVisible; const sal_Int32 nControlHeight = GetMaxControlHeight(); const sal_Int32 nControl_Spacing_y = LogicToPixel(Size(0, CONTROL_SPACING_Y),MapUnit::MapAppFont).Height(); if (bNeedHScrollBar) nLastVisible = static_cast((szOverallSize.Height() - nControl_Spacing_y - nHScrollHeight) / (nControl_Spacing_y + nControlHeight)); else nLastVisible = static_cast((szOverallSize.Height() - nControl_Spacing_y) / (nControl_Spacing_y + nControlHeight)); bNeedVScrollBar = nActive>nLastVisible; if (bNeedVScrollBar) { // When originally calculating lMaxXAvailable we did not take into account that we have a VScrollBar, so we need to do that now lMaxXAvailable -= nVScrollWidth; if (!bNeedHScrollBar && (lMaxXPosition > lMaxXAvailable)) { // The vertical one now necessitates a horizontal one bNeedHScrollBar = true; // Adjust nLastVisible nLastVisible = static_cast((szOverallSize.Height() - nControl_Spacing_y - nHScrollHeight) / (nControl_Spacing_y + nControlHeight)); // bNeedVScrollBar does NOT change: it's already set to sal_True and nLastVisible will only decrease } } // Now we can really position them and set their parameters if (bNeedVScrollBar) { m_pVertScroll->Show(); m_pVertScroll->SetRangeMax(nActive - nLastVisible); m_pVertScroll->SetPosSizePixel( Point(nNewHWidth, 0), Size(nVScrollWidth, szOverallSize.Height()) ); } else { m_pVertScroll->Hide(); m_pVertScroll->SetRangeMax(0); m_pVertScroll->SetThumbPos(0); } if (bNeedHScrollBar) { m_pHorzScroll->Show(); m_pHorzScroll->SetRangeMax((lMaxXPosition - lMaxXAvailable + HSCROLL_STEP - 1 )/HSCROLL_STEP); m_pHorzScroll->SetPosSizePixel( Point(0, nNewVHeight), Size(bNeedVScrollBar ? nNewHWidth : szOverallSize.Width(), nHScrollHeight) ); } else { m_pHorzScroll->Hide(); m_pHorzScroll->SetRangeMax(0); m_pHorzScroll->SetThumbPos(0); } } void OFieldDescControl::Resize() { CheckScrollBars(); ScrollAllAggregates(); } inline void OFieldDescControl::ScrollAggregate(Control* pText, Control* pInput, Control* pButton, long nDeltaX, long nDeltaY) { if (!pText) return; pText->SetPosPixel(pText->GetPosPixel() + Point(nDeltaX, nDeltaY)); pInput->SetPosPixel(pInput->GetPosPixel() + Point(nDeltaX, nDeltaY)); if (pButton) pButton->SetPosPixel(pButton->GetPosPixel() + Point(nDeltaX, nDeltaY)); } void OFieldDescControl::ScrollAllAggregates() { long nDeltaX = 0, nDeltaY = 0; if (m_nOldHThumb != m_pHorzScroll->GetThumbPos()) { nDeltaX = (m_nOldHThumb - m_pHorzScroll->GetThumbPos()) * HSCROLL_STEP; m_nOldHThumb = m_pHorzScroll->GetThumbPos(); } if (m_nOldVThumb != m_pVertScroll->GetThumbPos()) { const sal_Int32 nControlHeight = GetMaxControlHeight(); const sal_Int32 nControl_Spacing_y = LogicToPixel(Size(0, CONTROL_SPACING_Y),MapUnit::MapAppFont).Height(); nDeltaY = (m_nOldVThumb - m_pVertScroll->GetThumbPos()) * (nControl_Spacing_y + nControlHeight); m_nOldVThumb = m_pVertScroll->GetThumbPos(); } if (nDeltaX || nDeltaY) { Control* ppAggregates[] = { pRequired, pNumType , pAutoIncrement, pDefault , pTextLen, pLength , pScale, m_pColumnName , m_pType, m_pAutoIncrementValue}; Control* ppAggregatesText[] = { pRequiredText, pNumTypeText , pAutoIncrementText, pDefaultText , pTextLenText, pLengthText , pScaleText, m_pColumnNameText , m_pTypeText, m_pAutoIncrementValueText}; OSL_ENSURE(SAL_N_ELEMENTS(ppAggregates) == SAL_N_ELEMENTS(ppAggregatesText),"Lists are not identical!"); for (sal_uInt16 i=0; iGetOptimalSize()); if ( aTemp.Height() > aHeight.Height() ) aHeight.Height() = aTemp.Height(); } } return aHeight.Height(); } void OFieldDescControl::SetReadOnly( bool bReadOnly ) { // Enable/disable Controls Control* ppAggregates[] = { pRequired, pNumType , pAutoIncrement, pDefault , pTextLen, pLength , pScale, m_pColumnName , m_pType, m_pAutoIncrementValue , pFormat}; Control* ppAggregatesText[] = { pRequiredText, pNumTypeText , pAutoIncrementText, pDefaultText , pTextLenText, pLengthText , pScaleText, m_pColumnNameText , m_pTypeText, m_pAutoIncrementValueText , pFormatText}; OSL_ENSURE(SAL_N_ELEMENTS(ppAggregates) == SAL_N_ELEMENTS(ppAggregatesText),"Lists are not identical!"); for (sal_uInt16 i=0; iEnable( !bReadOnly ); if ( ppAggregates[i] ) ppAggregates[i]->Enable( !bReadOnly ); } } void OFieldDescControl::SetControlText( sal_uInt16 nControlId, const OUString& rText ) { // Set the Controls' texts switch( nControlId ) { case FIELD_PROPERTY_BOOL_DEFAULT: if (pBoolDefault) { OUString sOld = pBoolDefault->GetSelectEntry(); pBoolDefault->SelectEntry(rText); if (sOld != rText) LINK(this, OFieldDescControl, ChangeHdl).Call(*pBoolDefault); } break; case FIELD_PROPERTY_DEFAULT: if (pDefault) { pDefault->SetText(rText); UpdateFormatSample(pActFieldDescr); } break; case FIELD_PROPERTY_REQUIRED: if (pRequired) pRequired->SelectEntry(rText); break; case FIELD_PROPERTY_TEXTLEN: if (pTextLen) pTextLen->SetText(rText); break; case FIELD_PROPERTY_NUMTYPE: if (pNumType) pNumType->SelectEntry(rText); break; case FIELD_PROPERTY_AUTOINC: if (pAutoIncrement) { OUString sOld = pAutoIncrement->GetSelectEntry(); pAutoIncrement->SelectEntry(rText); if (sOld != rText) LINK(this, OFieldDescControl, ChangeHdl).Call(*pAutoIncrement); } break; case FIELD_PROPERTY_LENGTH: if (pLength) pLength->SetText(rText); break; case FIELD_PROPERTY_SCALE: if (pScale) pScale->SetText(rText); break; case FIELD_PROPERTY_FORMAT: if (pActFieldDescr) UpdateFormatSample(pActFieldDescr); break; case FIELD_PROPERTY_COLUMNNAME: if(m_pColumnName) m_pColumnName->SetText(rText); break; case FIELD_PROPERTY_TYPE: if(m_pType) m_pType->SelectEntry(rText); break; case FIELD_PROPERTY_AUTOINCREMENT: if(m_pAutoIncrementValue) m_pAutoIncrementValue->SetText(rText); break; } } IMPL_LINK_NOARG( OFieldDescControl, FormatClickHdl, Button *, void ) { // Create temporary Column, which is used for data exchange with Dialog if( !pActFieldDescr ) return; sal_Int32 nOldFormatKey(pActFieldDescr->GetFormatKey()); SvxCellHorJustify rOldJustify = pActFieldDescr->GetHorJustify(); Reference< XNumberFormatsSupplier > xSupplier = GetFormatter()->getNumberFormatsSupplier(); SvNumberFormatsSupplierObj* pSupplierImpl = SvNumberFormatsSupplierObj::getImplementation( xSupplier ); if (!pSupplierImpl) return; SvNumberFormatter* pFormatter = pSupplierImpl->GetNumberFormatter(); if(::dbaui::callColumnFormatDialog(this,pFormatter,pActFieldDescr->GetType(),nOldFormatKey,rOldJustify,true)) { bool bModified = false; if(nOldFormatKey != pActFieldDescr->GetFormatKey()) { pActFieldDescr->SetFormatKey( nOldFormatKey ); bModified = true; } if(rOldJustify != pActFieldDescr->GetHorJustify()) { pActFieldDescr->SetHorJustify( rOldJustify ); bModified = true; } if(bModified) { SetModified(true); UpdateFormatSample(pActFieldDescr); } } } void OFieldDescControl::SetModified(bool /*bModified*/) { } IMPL_LINK( OFieldDescControl, ChangeHdl, ListBox&, rListBox, void ) { if ( !pActFieldDescr ) return; if ( rListBox.IsValueChangedFromSaved() ) SetModified(true); // Special treatment for Bool fields if(&rListBox == pRequired && pBoolDefault ) { // If pRequired = sal_True then the sal_Bool field must NOT contain <> OUString sDef = BoolStringUI(::comphelper::getString(pActFieldDescr->GetControlDefault())); if(pRequired->GetSelectEntryPos() == 0) // Yes { pBoolDefault->RemoveEntry(OUString(ModuleRes(STR_VALUE_NONE))); if (sDef != aYes && sDef != aNo) pBoolDefault->SelectEntryPos(1); // No as a default else pBoolDefault->SelectEntry(sDef); } else if(pBoolDefault->GetEntryCount() < 3) { pBoolDefault->InsertEntry(OUString(ModuleRes(STR_VALUE_NONE))); pBoolDefault->SelectEntry(sDef); } } // A special treatment only for AutoIncrement if (&rListBox == pAutoIncrement) { if(rListBox.GetSelectEntryPos() == 1) { // no DeactivateAggregate( tpAutoIncrementValue ); if(pActFieldDescr->IsPrimaryKey()) DeactivateAggregate( tpRequired ); else if( pActFieldDescr->getTypeInfo()->bNullable ) { ActivateAggregate( tpRequired ); if(pRequired) { if( pActFieldDescr->IsNullable() ) pRequired->SelectEntryPos( 1 ); // no else pRequired->SelectEntryPos( 0 ); // yes } } ActivateAggregate( tpDefault ); } else { DeactivateAggregate( tpRequired ); DeactivateAggregate( tpDefault ); ActivateAggregate( tpAutoIncrementValue ); } // Move all up ArrangeAggregates(); } if(&rListBox == m_pType) { TOTypeInfoSP pTypeInfo = getTypeInfo(m_pType->GetSelectEntryPos()); pActFieldDescr->FillFromTypeInfo(pTypeInfo,true,false); // SetType(pTypeInfo); DisplayData(pActFieldDescr); CellModified(-1, m_pType->GetPos()); } } // Rearrange all Controls, such that they are in fixed order and really on top // of the DescriptionPage void OFieldDescControl::ArrangeAggregates() { // A Control's description struct AGGREGATE_DESCRIPTION { VclPtr pctrlInputControl; // The actual Control for input VclPtr pctrlTextControl; // The corresponding Label sal_uInt16 nPosSizeArgument; // The second argument for SetPosSize }; AGGREGATE_DESCRIPTION adAggregates[] = { { m_pColumnName, m_pColumnNameText, 1}, { m_pType, m_pTypeText, 1}, { pAutoIncrement, pAutoIncrementText, 1 }, { m_pAutoIncrementValue, m_pAutoIncrementValueText, 3 }, { pNumType, pNumTypeText, 1 }, { pRequired, pRequiredText, 1 }, { pTextLen, pTextLenText, 1 }, { pLength, pLengthText, 1 }, { pScale, pScaleText, 1 }, { pDefault, pDefaultText, 3 }, { pFormatSample, pFormatText, 4 }, { pBoolDefault, pBoolDefaultText, 1 }, }; long nMaxWidth = 0; for (const AGGREGATE_DESCRIPTION & adAggregate : adAggregates) { if (adAggregate.pctrlTextControl) { nMaxWidth = ::std::max(OutputDevice::GetTextWidth(adAggregate.pctrlTextControl->GetText()),nMaxWidth); } } OSL_ENSURE(nMaxWidth != 0,"Invalid width!"); // And go ... int nCurrentControlPos = 0; Control* pZOrderPredecessor = nullptr; for (AGGREGATE_DESCRIPTION & adAggregate : adAggregates) { if (adAggregate.pctrlInputControl) { SetPosSize(adAggregate.pctrlTextControl, nCurrentControlPos, 0); SetPosSize(adAggregate.pctrlInputControl, nCurrentControlPos, adAggregate.nPosSizeArgument); // Set the z-order in a way such that the Controls can be traversed in the same sequence in which they have been arranged here adAggregate.pctrlTextControl->SetZOrder(pZOrderPredecessor, pZOrderPredecessor ? ZOrderFlags::Behind : ZOrderFlags::First); adAggregate.pctrlInputControl->SetZOrder(adAggregate.pctrlTextControl, ZOrderFlags::Behind ); pZOrderPredecessor = adAggregate.pctrlInputControl; if (adAggregate.pctrlInputControl == pFormatSample) { pFormat->SetZOrder(pZOrderPredecessor, ZOrderFlags::Behind); pZOrderPredecessor = pFormat; } ++nCurrentControlPos; } } // Special treatment for the Format Controls if (pFormat) { Point ptSamplePos(pFormatSample->GetPosPixel()); Size szSampleSize(pFormatSample->GetSizePixel()); pFormat->SetPosPixel(Point(ptSamplePos.X() + szSampleSize.Width() + 5, ptSamplePos.Y())); } // Finally, put the ScrollBars at the top of the z-order m_pVertScroll->SetZOrder(nullptr, ZOrderFlags::First); m_pHorzScroll->SetZOrder(nullptr, ZOrderFlags::First); } void OFieldDescControl::ActivateAggregate( EControlType eType ) { // Create Controls switch( eType ) { case tpDefault: if( pDefault ) return; m_nPos++; pDefaultText = CreateText(STR_DEFAULT_VALUE); pDefault = VclPtr::Create( this, STR_HELP_DEFAULT_VALUE, FIELD_PROPERTY_DEFAULT, WB_BORDER ); InitializeControl(pDefault,HID_TAB_ENT_DEFAULT,false); break; case tpAutoIncrementValue: if( m_pAutoIncrementValue || !isAutoIncrementValueEnabled() ) return; m_nPos++; m_pAutoIncrementValueText = CreateText(STR_AUTOINCREMENT_VALUE); m_pAutoIncrementValue = VclPtr::Create( this, STR_HELP_AUTOINCREMENT_VALUE, FIELD_PROPERTY_AUTOINCREMENT, WB_BORDER ); m_pAutoIncrementValue->SetText( getAutoIncrementValue() ); InitializeControl(m_pAutoIncrementValue,HID_TAB_AUTOINCREMENTVALUE,false); break; case tpRequired: { if( pRequired ) return; Reference< XDatabaseMetaData> xMetaData = getMetaData(); if(xMetaData.is() && xMetaData->supportsNonNullableColumns()) { m_nPos++; pRequiredText = CreateText(STR_FIELD_REQUIRED); pRequired = VclPtr::Create( this, STR_HELP_FIELD_REQUIRED, FIELD_PROPERTY_REQUIRED, WB_DROPDOWN); pRequired->InsertEntry( aYes ); pRequired->InsertEntry( aNo ); pRequired->SelectEntryPos(1); InitializeControl(pRequired,HID_TAB_ENT_REQUIRED,true); } } break; case tpAutoIncrement: { if( pAutoIncrement ) return; m_nPos++; pAutoIncrementText = CreateText(STR_FIELD_AUTOINCREMENT); pAutoIncrement = VclPtr::Create( this, STR_HELP_AUTOINCREMENT, FIELD_PROPERTY_AUTOINC, WB_DROPDOWN ); pAutoIncrement->InsertEntry( aYes ); pAutoIncrement->InsertEntry( aNo ); pAutoIncrement->SelectEntryPos(0); InitializeControl(pAutoIncrement,HID_TAB_ENT_AUTOINCREMENT,true); } break; case tpTextLen: if( pTextLen ) return; m_nPos++; pTextLenText = CreateText(STR_TEXT_LENGTH); pTextLen = CreateNumericControl(STR_HELP_TEXT_LENGTH, FIELD_PROPERTY_TEXTLEN,HID_TAB_ENT_TEXT_LEN); break; case tpType: if( m_pType) return; m_nPos++; m_pTypeText = CreateText(STR_TAB_FIELD_DATATYPE); m_pType = VclPtr::Create( this, STR_HELP_AUTOINCREMENT, FIELD_PROPERTY_TYPE, WB_DROPDOWN ); m_pType->SetDropDownLineCount(20); { const OTypeInfoMap* pTypeInfo = getTypeInfo(); OTypeInfoMap::const_iterator aIter = pTypeInfo->begin(); OTypeInfoMap::const_iterator aEnd = pTypeInfo->end(); for(;aIter != aEnd;++aIter) m_pType->InsertEntry( aIter->second->aUIName ); } m_pType->SelectEntryPos(0); InitializeControl(m_pType,HID_TAB_ENT_TYPE,true); break; case tpColumnName: if( m_pColumnName ) return; m_nPos++; { sal_Int32 nMax = EDIT_NOLIMIT; OUString aTmpString; try { Reference< XDatabaseMetaData> xMetaData = getMetaData(); if ( xMetaData.is() ) { nMax = xMetaData->getMaxColumnNameLength(); aTmpString = xMetaData->getExtraNameCharacters(); } } catch (const Exception&) { DBG_UNHANDLED_EXCEPTION(); } m_pColumnNameText = CreateText(STR_TAB_FIELD_NAME); m_pColumnName = VclPtr::Create( this, aTmpString, STR_HELP_DEFAULT_VALUE, FIELD_PROPERTY_COLUMNNAME, WB_BORDER ); m_pColumnName->SetMaxTextLen(nMax ? nMax : EDIT_NOLIMIT); m_pColumnName->setCheck( isSQL92CheckEnabled(getConnection()) ); } InitializeControl(m_pColumnName,HID_TAB_ENT_COLUMNNAME,false); break; case tpNumType: if( pNumType ) return; m_nPos++; pNumTypeText = CreateText(STR_NUMERIC_TYPE); pNumType = VclPtr::Create( this, STR_HELP_NUMERIC_TYPE, FIELD_PROPERTY_NUMTYPE, WB_DROPDOWN ); pNumType->SetDropDownLineCount(5); pNumType->InsertEntry( OUString("Byte") ); pNumType->InsertEntry( OUString("SmallInt") ); pNumType->InsertEntry( OUString("Integer") ); pNumType->InsertEntry( OUString("Single") ); pNumType->InsertEntry( OUString("Double") ); pNumType->SelectEntryPos(2); InitializeControl(pNumType,HID_TAB_ENT_NUMTYP,true); break; case tpLength: if( pLength ) return; m_nPos++; pLengthText = CreateText(STR_LENGTH); pLength = CreateNumericControl(STR_HELP_LENGTH, FIELD_PROPERTY_LENGTH,HID_TAB_ENT_LEN); break; case tpScale: if( pScale ) return; m_nPos++; pScaleText = CreateText(STR_SCALE); pScale = CreateNumericControl(STR_HELP_SCALE, FIELD_PROPERTY_SCALE,HID_TAB_ENT_SCALE); break; case tpFormat: if (!pFormat) { m_nPos++; pFormatText = CreateText(STR_FORMAT); pFormatSample = VclPtr::Create( this, STR_HELP_FORMAT_CODE, -1, WB_BORDER ); pFormatSample->SetReadOnly(); pFormatSample->Enable(false); InitializeControl(pFormatSample,HID_TAB_ENT_FORMAT_SAMPLE,false); pFormat = VclPtr::Create(this, WB_TABSTOP); pFormat->SetText(ModuleRes(STR_BUTTON_FORMAT)); const sal_Int32 nControlHeight = GetMaxControlHeight(); pFormat->SetSizePixel(Size(nControlHeight, nControlHeight)); pFormat->SetClickHdl( LINK( this, OFieldDescControl, FormatClickHdl ) ); pFormat->Show(); InitializeControl(pFormat,HID_TAB_ENT_FORMAT,false); } UpdateFormatSample(pActFieldDescr); break; case tpBoolDefault: if (pBoolDefault) return; m_nPos++; pBoolDefaultText = CreateText(STR_DEFAULT_VALUE); pBoolDefault = VclPtr::Create( this, STR_HELP_BOOL_DEFAULT, FIELD_PROPERTY_BOOL_DEFAULT, WB_DROPDOWN ); pBoolDefault->SetDropDownLineCount(3); pBoolDefault->InsertEntry(OUString(ModuleRes(STR_VALUE_NONE))); pBoolDefault->InsertEntry(aYes); pBoolDefault->InsertEntry(aNo); InitializeControl(pBoolDefault,HID_TAB_ENT_BOOL_DEFAULT,false); break; } } void OFieldDescControl::InitializeControl(Control* _pControl,const OString& _sHelpId,bool _bAddChangeHandler) { _pControl->SetHelpId(_sHelpId); if ( _bAddChangeHandler ) static_cast(_pControl)->SetSelectHdl(LINK(this,OFieldDescControl,ChangeHdl)); _pControl->SetGetFocusHdl(LINK(this, OFieldDescControl, OnControlFocusGot)); _pControl->SetLoseFocusHdl(LINK(this, OFieldDescControl, OnControlFocusLost)); _pControl->EnableClipSiblings(); } VclPtr OFieldDescControl::CreateText(sal_uInt16 _nTextRes) { VclPtrInstance pFixedText( this ); pFixedText->SetText( ModuleRes(_nTextRes) ); pFixedText->EnableClipSiblings(); return pFixedText; } VclPtr OFieldDescControl::CreateNumericControl(sal_uInt16 _nHelpStr,short _nProperty,const OString& _sHelpId) { VclPtrInstance pControl( this, _nHelpStr, _nProperty, WB_BORDER ); pControl->SetDecimalDigits(0); pControl->SetMin(0); pControl->SetMax(0x7FFFFFFF); // Should be changed outside, if needed pControl->SetStrictFormat(true); InitializeControl(pControl,_sHelpId,false); return pControl; } void OFieldDescControl::DeactivateAggregate( EControlType eType ) { pLastFocusWindow = nullptr; // Destroy Controls switch( eType ) { case tpDefault: lcl_HideAndDeleteControl(m_nPos,pDefault,pDefaultText); break; case tpAutoIncrementValue: lcl_HideAndDeleteControl(m_nPos,m_pAutoIncrementValue,m_pAutoIncrementValueText); break; case tpColumnName: lcl_HideAndDeleteControl(m_nPos,m_pColumnName,m_pColumnNameText); break; case tpType: lcl_HideAndDeleteControl(m_nPos,m_pType,m_pTypeText); break; case tpAutoIncrement: lcl_HideAndDeleteControl(m_nPos,pAutoIncrement,pAutoIncrementText); break; case tpRequired: lcl_HideAndDeleteControl(m_nPos,pRequired,pRequiredText); break; case tpTextLen: lcl_HideAndDeleteControl(m_nPos,pTextLen,pTextLenText); break; case tpNumType: lcl_HideAndDeleteControl(m_nPos,pNumType,pNumTypeText); break; case tpLength: lcl_HideAndDeleteControl(m_nPos,pLength,pLengthText); break; case tpScale: lcl_HideAndDeleteControl(m_nPos,pScale,pScaleText); break; case tpFormat: // TODO: we have to check if we have to increment m_nPos again lcl_HideAndDeleteControl(m_nPos,pFormat,pFormatText); if ( pFormatSample ) { pFormatSample->Hide(); pFormatSample.disposeAndClear(); } break; case tpBoolDefault: lcl_HideAndDeleteControl(m_nPos,pBoolDefault,pBoolDefaultText); break; } } void OFieldDescControl::SetPosSize( VclPtr& rControl, long nRow, sal_uInt16 nCol ) { // Calculate size const sal_Int32 nControlHeight = GetMaxControlHeight(); Size aSize(0,nControlHeight); if ( isRightAligned() && nCol ) aSize.Width() = LogicToPixel(Size(m_nWidth, 0),MapUnit::MapAppFont).Width(); else { switch( nCol ) { case 0: default: aSize.Width() = CONTROL_WIDTH_1; break; case 1: aSize.Width() = CONTROL_WIDTH_2; break; case 3: aSize.Width() = CONTROL_WIDTH_3; break; case 4: aSize.Width() = CONTROL_WIDTH_4; break; } } // Calculate Position Point aPosition; switch( nCol ) { case 0: aPosition.X() = 0; aPosition.Y() = 1; break; case 1: case 3: case 4: if ( isRightAligned() ) { Size aOwnSize = GetSizePixel(); aPosition.X() = aOwnSize.Width() - aSize.Width(); } else aPosition.X() = CONTROL_WIDTH_1 + CONTROL_SPACING_X; break; default: aPosition.X() = 0; } rControl->SetSizePixel( aSize ); aSize = rControl->GetSizePixel( ); const sal_Int32 nControl_Spacing_y = LogicToPixel(Size(0, CONTROL_SPACING_Y),MapUnit::MapAppFont).Height(); aPosition.Y() += ((nRow+1)*nControl_Spacing_y) + (nRow*nControlHeight); // Display Control rControl->SetPosSizePixel( aPosition, aSize ); aSize = rControl->GetSizePixel(); rControl->Show(); } void OFieldDescControl::DisplayData(OFieldDescription* pFieldDescr ) { pActFieldDescr = pFieldDescr; if(!pFieldDescr) { DeactivateAggregate( tpDefault ); DeactivateAggregate( tpRequired ); DeactivateAggregate( tpTextLen ); DeactivateAggregate( tpNumType ); DeactivateAggregate( tpScale ); DeactivateAggregate( tpLength ); DeactivateAggregate( tpFormat ); DeactivateAggregate( tpAutoIncrement ); DeactivateAggregate( tpBoolDefault ); DeactivateAggregate( tpColumnName ); DeactivateAggregate( tpType ); DeactivateAggregate( tpAutoIncrementValue ); m_pPreviousType = TOTypeInfoSP(); // Reset the saved focus' pointer pLastFocusWindow = nullptr; if ( m_bAdded ) { ::dbaui::notifySystemWindow(this,this,::comphelper::mem_fun(&TaskPaneList::RemoveWindow)); m_bAdded = false; } return; } if ( !m_bAdded ) { ::dbaui::notifySystemWindow(this,this,::comphelper::mem_fun(&TaskPaneList::AddWindow)); m_bAdded = true; } TOTypeInfoSP pFieldType; if( pFieldDescr ) pFieldType = pFieldDescr->getTypeInfo(); ActivateAggregate( tpColumnName ); ActivateAggregate( tpType ); OSL_ENSURE(pFieldType.get(),"We need a type information here!"); // If the type has changed, substitute Controls if( m_pPreviousType != pFieldType ) { // Reset the saved focus' pointer pLastFocusWindow = nullptr; // Controls, which must NOT be displayed again DeactivateAggregate( tpNumType ); // determine which controls we should show and which not // 1. the required control if ( pFieldType->bNullable ) ActivateAggregate( tpRequired ); else DeactivateAggregate( tpRequired ); // 2. the autoincrement if ( pFieldType->bAutoIncrement ) { DeactivateAggregate( tpRequired ); DeactivateAggregate( tpDefault ); ActivateAggregate( tpAutoIncrement ); ActivateAggregate( tpAutoIncrementValue ); } else { DeactivateAggregate( tpAutoIncrement ); DeactivateAggregate( tpAutoIncrementValue ); if(pFieldType->bNullable) ActivateAggregate( tpRequired ); else DeactivateAggregate( tpRequired ); ActivateAggregate( tpDefault ); } // 3. the scale and precision if (pFieldType->nPrecision) { ActivateAggregate( tpLength ); pLength->SetMax(::std::max(pFieldType->nPrecision,pFieldDescr->GetPrecision())); pLength->SetSpecialReadOnly(pFieldType->aCreateParams.isEmpty()); } else DeactivateAggregate( tpLength ); if (pFieldType->nMaximumScale) { ActivateAggregate( tpScale ); pScale->SetMax(::std::max(pFieldType->nMaximumScale,pFieldDescr->GetScale())); pScale->SetMin(pFieldType->nMinimumScale); pScale->SetSpecialReadOnly(pFieldType->aCreateParams.isEmpty() || pFieldType->aCreateParams == "PRECISION"); } else DeactivateAggregate( tpScale ); // and now look for type specific things switch( pFieldType->nType ) { case DataType::CHAR: case DataType::VARCHAR: case DataType::LONGVARCHAR: DeactivateAggregate( tpLength ); DeactivateAggregate( tpBoolDefault ); ActivateAggregate( tpDefault ); ActivateAggregate( tpFormat ); if (pFieldType->nPrecision) { ActivateAggregate( tpTextLen ); pTextLen->SetMax(::std::max(pFieldType->nPrecision,pFieldDescr->GetPrecision())); pTextLen->SetSpecialReadOnly(pFieldType->aCreateParams.isEmpty()); } else DeactivateAggregate( tpTextLen ); break; case DataType::DATE: case DataType::TIME: case DataType::TIMESTAMP: DeactivateAggregate( tpLength ); // we don't need a length for date types DeactivateAggregate( tpTextLen ); DeactivateAggregate( tpBoolDefault ); ActivateAggregate( tpDefault ); ActivateAggregate( tpFormat ); break; case DataType::BIT: if ( !pFieldType->aCreateParams.isEmpty() ) { DeactivateAggregate( tpFormat ); DeactivateAggregate( tpTextLen ); DeactivateAggregate( tpBoolDefault ); break; } SAL_FALLTHROUGH; case DataType::BOOLEAN: DeactivateAggregate( tpTextLen ); DeactivateAggregate( tpFormat ); DeactivateAggregate( tpDefault ); ActivateAggregate( tpBoolDefault ); break; case DataType::DECIMAL: case DataType::NUMERIC: case DataType::BIGINT: case DataType::FLOAT: case DataType::DOUBLE: case DataType::TINYINT: case DataType::SMALLINT: case DataType::INTEGER: case DataType::REAL: DeactivateAggregate( tpTextLen ); DeactivateAggregate( tpBoolDefault ); ActivateAggregate( tpFormat ); break; case DataType::BINARY: case DataType::VARBINARY: DeactivateAggregate( tpDefault ); DeactivateAggregate( tpRequired ); DeactivateAggregate( tpTextLen ); DeactivateAggregate( tpBoolDefault ); ActivateAggregate( tpFormat ); break; case DataType::LONGVARBINARY: case DataType::SQLNULL: case DataType::OBJECT: case DataType::DISTINCT: case DataType::STRUCT: case DataType::ARRAY: case DataType::BLOB: case DataType::CLOB: case DataType::REF: case DataType::OTHER: DeactivateAggregate( tpFormat ); DeactivateAggregate( tpTextLen ); DeactivateAggregate( tpBoolDefault ); break; default: OSL_FAIL("Unknown type"); } m_pPreviousType = pFieldType; } if(pFieldDescr) { if(pFieldDescr->IsPrimaryKey()) { DeactivateAggregate( tpRequired ); } else if ( !pAutoIncrement && pFieldType.get() ) { if ( pFieldType->bNullable ) ActivateAggregate( tpRequired ); else DeactivateAggregate( tpRequired ); } } // Initialize Controls if( pAutoIncrement ) { if ( pFieldDescr->IsAutoIncrement() ) { pAutoIncrement->SelectEntryPos( 0 ); // yes ActivateAggregate( tpAutoIncrementValue ); if ( m_pAutoIncrementValue ) m_pAutoIncrementValue->SetText(pFieldDescr->GetAutoIncrementValue()); DeactivateAggregate( tpRequired ); DeactivateAggregate( tpDefault ); } else { // disable autoincrement value because it should only be visible when autoincrement is to true DeactivateAggregate( tpAutoIncrementValue ); pAutoIncrement->SelectEntryPos( 1 ); // no ActivateAggregate( tpDefault ); // Affects pRequired if(!pFieldDescr->IsPrimaryKey()) ActivateAggregate( tpRequired ); } } if( pDefault ) { pDefault->SetText( getControlDefault(pFieldDescr) ); pDefault->ClearModifyFlag(); } if( pBoolDefault ) { // If pRequired = sal_True then the sal_Bool field must NOT contain <> OUString sValue; pFieldDescr->GetControlDefault() >>= sValue; OUString sDef = BoolStringUI(sValue); // Make sure that <> is only present if the field can be NULL if ( ( pFieldType.get() && !pFieldType->bNullable ) || !pFieldDescr->IsNullable() ) { pFieldDescr->SetIsNullable(ColumnValue::NO_NULLS); // The type says so pBoolDefault->RemoveEntry(OUString(ModuleRes(STR_VALUE_NONE))); if ( sDef != aYes && sDef != aNo ) pBoolDefault->SelectEntryPos(1); // No as a default else pBoolDefault->SelectEntry(sDef); pFieldDescr->SetControlDefault(makeAny(OUString(BoolStringPersistent(pBoolDefault->GetSelectEntry())))); } else if(pBoolDefault->GetEntryCount() < 3) { pBoolDefault->InsertEntry(OUString(ModuleRes(STR_VALUE_NONE))); pBoolDefault->SelectEntry(sDef); } else pBoolDefault->SelectEntry(sDef); } if( pRequired ) { if( pFieldDescr->IsNullable() ) pRequired->SelectEntryPos( 1 ); // no else pRequired->SelectEntryPos( 0 ); // yes } if( pTextLen ) { pTextLen->SetText( OUString::number(pFieldDescr->GetPrecision()) ); pTextLen->ClearModifyFlag(); } if( pNumType ) { OSL_FAIL("OFieldDescControl::DisplayData: invalid num type!"); } if( pLength ) pLength->SetText( OUString::number(pFieldDescr->GetPrecision()) ); if( pScale ) pScale->SetText( OUString::number(pFieldDescr->GetScale()) ); if( pFormat ) UpdateFormatSample(pFieldDescr); if(m_pColumnName) m_pColumnName->SetText(pFieldDescr->GetName()); if(m_pType) { sal_Int32 nPos = pFieldType.get() ? m_pType->GetEntryPos(OUString(pFieldDescr->getTypeInfo()->aUIName)) : LISTBOX_ENTRY_NOTFOUND; if(nPos == LISTBOX_ENTRY_NOTFOUND) { const OTypeInfoMap* pMap = getTypeInfo(); OTypeInfoMap::const_iterator aIter = pMap->find(pFieldType.get() ? pFieldDescr->getTypeInfo()->nType : pFieldDescr->GetType()); if(aIter == pMap->end() && !pMap->empty()) { aIter = pMap->begin(); if(pFieldDescr->GetPrecision() > aIter->second->nPrecision) pFieldDescr->SetPrecision(aIter->second->nPrecision); if(pFieldDescr->GetScale() > aIter->second->nMaximumScale) pFieldDescr->SetScale(0); if(!aIter->second->bNullable && pFieldDescr->IsNullable()) pFieldDescr->SetIsNullable(ColumnValue::NO_NULLS); if(!aIter->second->bAutoIncrement && pFieldDescr->IsAutoIncrement()) pFieldDescr->SetAutoIncrement(false); } if ( aIter != pMap->end() ) { pFieldDescr->SetType(aIter->second); } } m_pType->SelectEntry(pFieldDescr->getTypeInfo()->aUIName); } // Enable/disable Controls bool bRead(IsReadOnly()); ArrangeAggregates(); CheckScrollBars(); ScrollAllAggregates(); SetReadOnly( bRead ); } IMPL_LINK(OFieldDescControl, OnControlFocusGot, Control&, rControl, void ) { OUString strHelpText; OPropNumericEditCtrl* pNumeric = dynamic_cast< OPropNumericEditCtrl* >( &rControl ); if ( pNumeric ) { pNumeric->SaveValue(); strHelpText = pNumeric->GetHelp(); } OPropColumnEditCtrl* pColumn = dynamic_cast< OPropColumnEditCtrl* >( &rControl ); if ( pColumn ) { pColumn->SaveValue(); strHelpText = pColumn->GetHelp(); } OPropEditCtrl* pEdit = dynamic_cast< OPropEditCtrl* >( &rControl ); if ( pEdit ) { pEdit->SaveValue(); strHelpText = pEdit->GetHelp(); } OPropListBoxCtrl* pListBox = dynamic_cast< OPropListBoxCtrl* >( &rControl ); if ( pListBox ) { pListBox->SaveValue(); strHelpText = pListBox->GetHelp(); } if (&rControl == pFormat) strHelpText = ModuleRes(STR_HELP_FORMAT_BUTTON); if (!strHelpText.isEmpty() && (pHelp != nullptr)) pHelp->SetHelpText(strHelpText); m_pActFocusWindow = &rControl; } IMPL_LINK(OFieldDescControl, OnControlFocusLost, Control&, rControl, void ) { if ((&rControl == pLength) || (&rControl == pTextLen) || (&rControl == pScale)) { OPropNumericEditCtrl* pConverted = static_cast(&rControl); if (pConverted->IsModified()) CellModified(-1, pConverted->GetPos()); } if(&rControl == m_pColumnName) { OPropColumnEditCtrl* pConverted = static_cast(&rControl); if (pConverted->IsModified()) CellModified(-1, pConverted->GetPos()); } else if ((&rControl == pDefault) || (&rControl == pFormatSample) || (&rControl == m_pAutoIncrementValue) ) { OPropEditCtrl* pConverted = static_cast(&rControl); if (pConverted->IsModified()) CellModified(-1, pConverted->GetPos()); } else if ((&rControl == pRequired) || (&rControl == pNumType) || (&rControl == pAutoIncrement) || (&rControl == pBoolDefault) || (&rControl == m_pType)) { OPropListBoxCtrl* pConverted = static_cast(&rControl); if (pConverted->IsModified()) CellModified(-1, pConverted->GetPos()); } if (&rControl == pDefault) UpdateFormatSample(pActFieldDescr); implFocusLost(&rControl); } void OFieldDescControl::SaveData( OFieldDescription* pFieldDescr ) { if( !pFieldDescr ) return; // Read out Controls OUString sDefault; if (pDefault) { sDefault = pDefault->GetText(); } else if (pBoolDefault) { sDefault = BoolStringPersistent(pBoolDefault->GetSelectEntry()); } if ( !sDefault.isEmpty() ) pFieldDescr->SetControlDefault(makeAny(sDefault)); else pFieldDescr->SetControlDefault(Any()); if((pRequired && pRequired->GetSelectEntryPos() == 0) || pFieldDescr->IsPrimaryKey() || (pBoolDefault && pBoolDefault->GetEntryCount() == 2)) // yes pFieldDescr->SetIsNullable( ColumnValue::NO_NULLS ); else pFieldDescr->SetIsNullable( ColumnValue::NULLABLE ); if ( pAutoIncrement ) pFieldDescr->SetAutoIncrement( pAutoIncrement->GetSelectEntryPos() == 0 ); if( pTextLen ) pFieldDescr->SetPrecision( static_cast(pTextLen->GetValue()) ); else if( pLength ) pFieldDescr->SetPrecision( static_cast(pLength->GetValue()) ); if( pScale ) pFieldDescr->SetScale( static_cast(pScale->GetValue()) ); if(m_pColumnName) pFieldDescr->SetName(m_pColumnName->GetText()); if ( m_pAutoIncrementValue && isAutoIncrementValueEnabled() ) pFieldDescr->SetAutoIncrementValue(m_pAutoIncrementValue->GetText()); } void OFieldDescControl::UpdateFormatSample(OFieldDescription* pFieldDescr) { if ( pFieldDescr && pFormatSample ) pFormatSample->SetText(getControlDefault(pFieldDescr,false)); } void OFieldDescControl::GetFocus() { // Set the Focus to the Control that has been active last TabPage::GetFocus(); if( pLastFocusWindow ) { pLastFocusWindow->GrabFocus(); pLastFocusWindow = nullptr; } } void OFieldDescControl::implFocusLost(vcl::Window* _pWhich) { OSL_ENSURE(!_pWhich || IsChild(_pWhich), "OFieldDescControl::implFocusLost : invalid window !"); // Remember the active Control if (!pLastFocusWindow) pLastFocusWindow = _pWhich; // Reset HelpText if (pHelp && !pHelp->HasChildPathFocus()) pHelp->SetHelpText( OUString() ); } void OFieldDescControl::LoseFocus() { implFocusLost(nullptr); TabPage::LoseFocus(); } bool OFieldDescControl::isCopyAllowed() { bool bAllowed = (m_pActFocusWindow != nullptr) && (m_pActFocusWindow == pDefault || m_pActFocusWindow == pFormatSample || m_pActFocusWindow == pTextLen || m_pActFocusWindow == pLength || m_pActFocusWindow == pScale || m_pActFocusWindow == m_pColumnName || m_pActFocusWindow == m_pAutoIncrementValue) && !static_cast(m_pActFocusWindow.get())->GetSelected().isEmpty(); return bAllowed; } bool OFieldDescControl::isCutAllowed() { bool bAllowed = (m_pActFocusWindow != nullptr) && (m_pActFocusWindow == pDefault || m_pActFocusWindow == pFormatSample || m_pActFocusWindow == pTextLen || m_pActFocusWindow == pLength || m_pActFocusWindow == pScale || m_pActFocusWindow == m_pColumnName || m_pActFocusWindow == m_pAutoIncrementValue) && !static_cast(m_pActFocusWindow.get())->GetSelected().isEmpty(); return bAllowed; } bool OFieldDescControl::isPasteAllowed() { bool bAllowed = (m_pActFocusWindow != nullptr) && (m_pActFocusWindow == pDefault || m_pActFocusWindow == pFormatSample || m_pActFocusWindow == pTextLen || m_pActFocusWindow == pLength || m_pActFocusWindow == pScale || m_pActFocusWindow == m_pColumnName || m_pActFocusWindow == m_pAutoIncrementValue); if ( bAllowed ) { TransferableDataHelper aTransferData(TransferableDataHelper::CreateFromSystemClipboard(GetParent())); bAllowed = aTransferData.HasFormat(SotClipboardFormatId::STRING); } return bAllowed; } void OFieldDescControl::cut() { if(isCutAllowed()) static_cast(m_pActFocusWindow.get())->Cut(); } void OFieldDescControl::copy() { if(isCopyAllowed()) // this only checks if the focus window is valid static_cast(m_pActFocusWindow.get())->Copy(); } void OFieldDescControl::paste() { if(m_pActFocusWindow) // this only checks if the focus window is valid static_cast(m_pActFocusWindow.get())->Paste(); } bool OFieldDescControl::isTextFormat(const OFieldDescription* _pFieldDescr, sal_uInt32& _nFormatKey) const { _nFormatKey = _pFieldDescr->GetFormatKey(); bool bTextFormat = true; try { if (!_nFormatKey) { Reference< css::util::XNumberFormatTypes> xNumberTypes(GetFormatter()->getNumberFormatsSupplier()->getNumberFormats(),UNO_QUERY); OSL_ENSURE(xNumberTypes.is(),"XNumberFormatTypes is null!"); _nFormatKey = ::dbtools::getDefaultNumberFormat( _pFieldDescr->GetType(), _pFieldDescr->GetScale(), _pFieldDescr->IsCurrency(), xNumberTypes, GetLocale()); } sal_Int32 nNumberFormat = ::comphelper::getNumberFormatType(GetFormatter(),_nFormatKey); bTextFormat = (nNumberFormat == css::util::NumberFormat::TEXT); } catch(const Exception&) { } return bTextFormat; } OUString OFieldDescControl::getControlDefault( const OFieldDescription* _pFieldDescr, bool _bCheck) const { OUString sDefault; bool bCheck = !_bCheck || _pFieldDescr->GetControlDefault().hasValue(); if ( bCheck ) { sal_uInt32 nFormatKey; try { double nValue = 0.0; bool bTextFormat = isTextFormat(_pFieldDescr,nFormatKey); if ( _pFieldDescr->GetControlDefault() >>= sDefault ) { if ( !bTextFormat ) { if ( !sDefault.isEmpty() ) { try { nValue = GetFormatter()->convertStringToNumber(nFormatKey,sDefault); } catch(const Exception&) { return OUString(); // return empty string for format example } } } } else _pFieldDescr->GetControlDefault() >>= nValue; Reference< css::util::XNumberFormatter> xNumberFormatter = GetFormatter(); Reference xFormSet = xNumberFormatter->getNumberFormatsSupplier()->getNumberFormats()->getByKey(nFormatKey); OSL_ENSURE(xFormSet.is(),"XPropertySet is null!"); OUString sFormat; xFormSet->getPropertyValue("FormatString") >>= sFormat; if ( !bTextFormat ) { Locale aLocale; ::comphelper::getNumberFormatProperty(xNumberFormatter,nFormatKey,"Locale") >>= aLocale; sal_Int32 nNumberFormat = ::comphelper::getNumberFormatType(xNumberFormatter,nFormatKey); if( (nNumberFormat & css::util::NumberFormat::DATE) == css::util::NumberFormat::DATE || (nNumberFormat & css::util::NumberFormat::DATETIME) == css::util::NumberFormat::DATETIME ) { nValue = DBTypeConversion::toNullDate(DBTypeConversion::getNULLDate(xNumberFormatter->getNumberFormatsSupplier()),nValue); } Reference< css::util::XNumberFormatPreviewer> xPreviewer(xNumberFormatter,UNO_QUERY); OSL_ENSURE(xPreviewer.is(),"XNumberFormatPreviewer is null!"); sDefault = xPreviewer->convertNumberToPreviewString(sFormat,nValue,aLocale,true); } else if ( !(_bCheck && sDefault.isEmpty()) ) sDefault = xNumberFormatter->formatString(nFormatKey, sDefault.isEmpty() ? sFormat : sDefault); } catch(const Exception&) { } } return sDefault; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */