sc: factor out some more code
[LibreOffice.git] / sw / source / ui / misc / pggrid.cxx
blob743a108e1d731edff650cac1c9e9c5f240f45277
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <cmdid.h>
21 #include <hintids.hxx>
22 #include <svx/colorbox.hxx>
23 #include <editeng/sizeitem.hxx>
24 #include <editeng/lrspitem.hxx>
25 #include <editeng/ulspitem.hxx>
26 #include <editeng/boxitem.hxx>
27 #include <editeng/frmdiritem.hxx>
28 #include <svx/ruler.hxx>
29 #include <pggrid.hxx>
30 #include <tgrditem.hxx>
31 #include <svx/pageitem.hxx>
33 #include <wrtsh.hxx>
34 #include <doc.hxx>
35 #include <swmodule.hxx>
36 #include <view.hxx>
38 constexpr tools::Long constTwips_5mm = o3tl::toTwips(5, o3tl::Length::mm);
40 SwTextGridPage::SwTextGridPage(weld::Container* pPage, weld::DialogController* pController, const SfxItemSet &rSet)
41 : SfxTabPage(pPage, pController, u"modules/swriter/ui/textgridpage.ui"_ustr, u"TextGridPage"_ustr, &rSet)
42 , m_nRubyUserValue(0)
43 , m_bRubyUserValue(false)
44 , m_aPageSize(constTwips_5mm, constTwips_5mm)
45 , m_bVertical(false)
46 , m_bSquaredMode(false)
47 , m_bHRulerChanged(false)
48 , m_bVRulerChanged(false)
49 , m_xNoGridRB(m_xBuilder->weld_radio_button(u"radioRB_NOGRID"_ustr))
50 , m_xLinesGridRB(m_xBuilder->weld_radio_button(u"radioRB_LINESGRID"_ustr))
51 , m_xCharsGridRB(m_xBuilder->weld_radio_button(u"radioRB_CHARSGRID"_ustr))
52 , m_xSnapToCharsCB(m_xBuilder->weld_check_button(u"checkCB_SNAPTOCHARS"_ustr))
53 , m_xExampleWN(new weld::CustomWeld(*m_xBuilder, u"drawingareaWN_EXAMPLE"_ustr, m_aExampleWN))
54 , m_xLayoutFL(m_xBuilder->weld_widget(u"frameFL_LAYOUT"_ustr))
55 , m_xLinesPerPageNF(m_xBuilder->weld_spin_button(u"spinNF_LINESPERPAGE"_ustr))
56 , m_xLinesRangeFT(m_xBuilder->weld_label(u"labelFT_LINERANGE"_ustr))
57 , m_xTextSizeMF(m_xBuilder->weld_metric_spin_button(u"spinMF_TEXTSIZE"_ustr, FieldUnit::POINT))
58 , m_xCharsPerLineFT(m_xBuilder->weld_label(u"labelFT_CHARSPERLINE"_ustr))
59 , m_xCharsPerLineNF(m_xBuilder->weld_spin_button(u"spinNF_CHARSPERLINE"_ustr))
60 , m_xCharsRangeFT(m_xBuilder->weld_label(u"labelFT_CHARRANGE"_ustr))
61 , m_xCharWidthFT(m_xBuilder->weld_label(u"labelFT_CHARWIDTH"_ustr))
62 , m_xCharWidthMF(m_xBuilder->weld_metric_spin_button(u"spinMF_CHARWIDTH"_ustr, FieldUnit::POINT))
63 , m_xRubySizeFT(m_xBuilder->weld_label(u"labelFT_RUBYSIZE"_ustr))
64 , m_xRubySizeMF(m_xBuilder->weld_metric_spin_button(u"spinMF_RUBYSIZE"_ustr, FieldUnit::POINT))
65 , m_xRubyBelowCB(m_xBuilder->weld_check_button(u"checkCB_RUBYBELOW"_ustr))
66 , m_xDisplayFL(m_xBuilder->weld_widget(u"frameFL_DISPLAY"_ustr))
67 , m_xDisplayCB(m_xBuilder->weld_check_button(u"checkCB_DISPLAY"_ustr))
68 , m_xPrintCB(m_xBuilder->weld_check_button(u"checkCB_PRINT"_ustr))
69 , m_xColorLB(new ColorListBox(m_xBuilder->weld_menu_button(u"listLB_COLOR"_ustr),
70 [this]{ return GetDialogController()->getDialog(); }))
72 Link<weld::SpinButton&,void> aLink = LINK(this, SwTextGridPage, CharorLineChangedHdl);
73 m_xCharsPerLineNF->connect_value_changed(aLink);
74 m_xLinesPerPageNF->connect_value_changed(aLink);
76 Link<weld::MetricSpinButton&,void> aSizeLink = LINK(this, SwTextGridPage, TextSizeChangedHdl);
77 m_xTextSizeMF->connect_value_changed(aSizeLink);
78 m_xRubySizeMF->connect_value_changed(aSizeLink);
79 m_xCharWidthMF->connect_value_changed(aSizeLink);
81 Link<weld::Toggleable&,void> aGridTypeHdl = LINK(this, SwTextGridPage, GridTypeHdl);
82 m_xNoGridRB->connect_toggled(aGridTypeHdl);
83 m_xLinesGridRB->connect_toggled(aGridTypeHdl);
84 m_xCharsGridRB->connect_toggled(aGridTypeHdl);
86 m_xColorLB->SetSelectHdl(LINK(this, SwTextGridPage, ColorModifyHdl));
87 m_xPrintCB->connect_toggled(LINK(this, SwTextGridPage, GridModifyClickHdl));
88 m_xRubyBelowCB->connect_toggled(LINK(this, SwTextGridPage, GridModifyClickHdl));
90 m_xDisplayCB->connect_toggled(LINK(this, SwTextGridPage, DisplayGridHdl));
92 //Get the default paper mode
93 if (SwView *pView = GetActiveView())
95 if (SwWrtShell* pSh = pView->GetWrtShellPtr())
97 m_bSquaredMode = pSh->GetDoc()->IsSquaredPageMode();
100 if( m_bSquaredMode )
103 m_xRubySizeFT->show();
104 m_xRubySizeMF->show();
105 m_xRubyBelowCB->show();
106 m_xSnapToCharsCB->hide();
107 m_xCharWidthFT->hide();
108 m_xCharWidthMF->hide();
110 else
112 m_xRubySizeFT->hide();
113 m_xRubySizeMF->hide();
114 m_xRubyBelowCB->hide();
115 m_xSnapToCharsCB->show();
116 m_xCharWidthFT->show();
117 m_xCharWidthMF->show();
121 SwTextGridPage::~SwTextGridPage()
123 m_xColorLB.reset();
126 std::unique_ptr<SfxTabPage> SwTextGridPage::Create(weld::Container* pPage, weld::DialogController* pController, const SfxItemSet *rSet)
128 return std::make_unique<SwTextGridPage>(pPage, pController, *rSet);
131 bool SwTextGridPage::FillItemSet(SfxItemSet *rSet)
133 bool bRet = false;
134 if (m_xNoGridRB->get_state_changed_from_saved() ||
135 m_xLinesGridRB->get_state_changed_from_saved() ||
136 m_xLinesPerPageNF->get_value_changed_from_saved() ||
137 m_xTextSizeMF->get_value_changed_from_saved() ||
138 m_xCharsPerLineNF->get_value_changed_from_saved() ||
139 m_xSnapToCharsCB->get_state_changed_from_saved() ||
140 m_xRubySizeMF->get_value_changed_from_saved() ||
141 m_xCharWidthMF->get_value_changed_from_saved() ||
142 m_xRubyBelowCB->get_state_changed_from_saved() ||
143 m_xDisplayCB->get_state_changed_from_saved() ||
144 m_xPrintCB->get_state_changed_from_saved() ||
145 m_xColorLB->IsValueChangedFromSaved())
147 PutGridItem(*rSet);
148 bRet = true;
151 // draw ticks of ruler
152 if (SwView * pView = GetActiveView())
154 if ( m_bHRulerChanged )
155 pView->GetHRuler().DrawTicks();
156 if ( m_bVRulerChanged )
157 pView->GetVRuler().DrawTicks();
159 return bRet;
162 void SwTextGridPage::Reset(const SfxItemSet *rSet)
164 sal_Int32 nLinesPerPage = 0;
166 if(SfxItemState::DEFAULT <= rSet->GetItemState(RES_TEXTGRID))
168 const SwTextGridItem& rGridItem = rSet->Get(RES_TEXTGRID);
169 weld::RadioButton* pButton = nullptr;
170 switch(rGridItem.GetGridType())
172 case SwTextGrid::NONE : pButton = m_xNoGridRB.get(); break;
173 case SwTextGrid::LinesOnly: pButton = m_xLinesGridRB.get(); break;
174 default: pButton = m_xCharsGridRB.get();
176 pButton->set_active(true);
177 m_xDisplayCB->set_active(rGridItem.IsDisplayGrid());
178 GridTypeHdl(*pButton);
179 m_xSnapToCharsCB->set_active(rGridItem.IsSnapToChars());
180 nLinesPerPage = rGridItem.GetLines();
182 SetLinesOrCharsRanges(*m_xLinesRangeFT , m_xLinesPerPageNF->get_max());
183 m_nRubyUserValue = rGridItem.GetBaseHeight();
184 m_bRubyUserValue = true;
185 m_xTextSizeMF->set_value(m_xTextSizeMF->normalize(m_nRubyUserValue), FieldUnit::TWIP);
186 m_xRubySizeMF->set_value(m_xRubySizeMF->normalize(rGridItem.GetRubyHeight()), FieldUnit::TWIP);
187 m_xCharWidthMF->set_value(m_xCharWidthMF->normalize(rGridItem.GetBaseWidth()), FieldUnit::TWIP);
188 m_xRubyBelowCB->set_active(rGridItem.IsRubyTextBelow());
189 m_xPrintCB->set_active(rGridItem.IsPrintGrid());
190 m_xColorLB->SelectEntry(rGridItem.GetColor());
192 UpdatePageSize(*rSet);
194 if (nLinesPerPage > 0)
195 m_xLinesPerPageNF->set_value(nLinesPerPage);
197 m_xNoGridRB->save_state();
198 m_xLinesGridRB->save_state();
199 m_xSnapToCharsCB->save_state();
200 m_xLinesPerPageNF->save_value();
201 m_xTextSizeMF->save_value();
202 m_xCharsPerLineNF->save_value();
203 m_xRubySizeMF->save_value();
204 m_xCharWidthMF->save_value();
205 m_xRubyBelowCB->save_state();
206 m_xDisplayCB->save_state();
207 m_xPrintCB->save_state();
208 m_xColorLB->SaveValue();
211 void SwTextGridPage::ActivatePage( const SfxItemSet& rSet )
213 m_aExampleWN.Hide();
214 m_aExampleWN.UpdateExample(rSet);
215 UpdatePageSize(rSet);
216 m_aExampleWN.Show();
217 m_aExampleWN.Invalidate();
220 DeactivateRC SwTextGridPage::DeactivatePage( SfxItemSet* )
222 return DeactivateRC::LeavePage;
225 void SwTextGridPage::PutGridItem(SfxItemSet& rSet)
227 SwTextGridItem aGridItem;
228 aGridItem.SetGridType(m_xNoGridRB->get_active() ? SwTextGrid::NONE :
229 m_xLinesGridRB->get_active() ? SwTextGrid::LinesOnly : SwTextGrid::LinesAndChars );
230 aGridItem.SetSnapToChars(m_xSnapToCharsCB->get_active());
231 aGridItem.SetLines( static_cast< sal_Int32 >(m_xLinesPerPageNF->get_value()) );
232 aGridItem.SetBaseHeight( static_cast< sal_uInt16 >(
233 m_bRubyUserValue ? m_nRubyUserValue :
234 m_xTextSizeMF->denormalize(m_xTextSizeMF->get_value(FieldUnit::TWIP))) );
235 // Tdf#151544: set ruby height from the value get from UI only when in square page mode.
236 // When in normal mode, the ruby height should be zero.
237 if (m_bSquaredMode)
238 aGridItem.SetRubyHeight(static_cast<sal_uInt16>(m_xRubySizeMF->denormalize(m_xRubySizeMF->get_value(FieldUnit::TWIP))));
239 else
240 aGridItem.SetRubyHeight(0);
241 aGridItem.SetBaseWidth( static_cast< sal_uInt16 >(m_xCharWidthMF->denormalize(m_xCharWidthMF->get_value(FieldUnit::TWIP))) );
242 aGridItem.SetRubyTextBelow(m_xRubyBelowCB->get_active());
243 aGridItem.SetSquaredMode(m_bSquaredMode);
244 aGridItem.SetDisplayGrid(m_xDisplayCB->get_active());
245 aGridItem.SetPrintGrid(m_xPrintCB->get_active());
246 aGridItem.SetColor(m_xColorLB->GetSelectEntryColor());
247 rSet.Put(aGridItem);
249 SwView * pView = ::GetActiveView();
250 if (pView && aGridItem.GetGridType() != SwTextGrid::NONE)
252 if ( aGridItem.GetGridType() == SwTextGrid::LinesAndChars )
254 m_bHRulerChanged = true;
256 m_bVRulerChanged = true;
257 pView->GetHRuler().SetCharWidth(m_xCharWidthMF->get_value(FieldUnit::MM));
258 pView->GetVRuler().SetLineHeight(m_xTextSizeMF->get_value(FieldUnit::MM));
262 void SwTextGridPage::UpdatePageSize(const SfxItemSet& rSet)
264 if( SfxItemState::UNKNOWN != rSet.GetItemState( RES_FRAMEDIR ))
266 const SvxFrameDirectionItem& rDirItem =
267 rSet.Get(RES_FRAMEDIR);
268 m_bVertical = rDirItem.GetValue() == SvxFrameDirection::Vertical_RL_TB||
269 rDirItem.GetValue() == SvxFrameDirection::Vertical_LR_TB;
272 if( SfxItemState::SET != rSet.GetItemState( SID_ATTR_PAGE_SIZE ))
273 return;
275 const SvxSizeItem& rSize = rSet.Get(SID_ATTR_PAGE_SIZE);
276 const SvxLRSpaceItem& rLRSpace = rSet.Get( RES_LR_SPACE );
277 const SvxULSpaceItem& rULSpace = rSet.Get( RES_UL_SPACE );
278 const SvxBoxItem& rBox = rSet.Get(RES_BOX);
279 sal_Int32 nDistanceLR = rLRSpace.ResolveLeft({}) + rLRSpace.ResolveRight({});
280 sal_Int32 nDistanceUL = rULSpace.GetUpper() + rULSpace.GetLower();
282 for( const TypedWhichId<SvxSetItem> & nId : { SID_ATTR_PAGE_HEADERSET, SID_ATTR_PAGE_FOOTERSET })
284 if( const SvxSetItem* pItem = rSet.GetItemIfSet( nId, false ) )
286 const SfxItemSet& rExtraSet = pItem->GetItemSet();
287 const SfxBoolItem& rOn =
288 rExtraSet.Get( rSet.GetPool()->GetWhichIDFromSlotID( SID_ATTR_PAGE_ON ) );
290 if ( rOn.GetValue() )
292 const SvxSizeItem& rSizeItem =
293 rExtraSet.Get(rSet.GetPool()->GetWhichIDFromSlotID(SID_ATTR_PAGE_SIZE));
294 nDistanceUL += rSizeItem.GetSize().Height();
299 sal_Int32 nValue1 = rSize.GetSize().Height() - nDistanceUL -
300 rBox.GetDistance(SvxBoxItemLine::TOP) -
301 rBox.GetDistance(SvxBoxItemLine::BOTTOM);
302 sal_Int32 nValue2 = rSize.GetSize().Width() - nDistanceLR -
303 rBox.GetDistance(SvxBoxItemLine::LEFT) -
304 rBox.GetDistance(SvxBoxItemLine::RIGHT);
305 if(m_bVertical)
307 m_aPageSize.setWidth( nValue1 );
308 m_aPageSize.setHeight( nValue2 );
310 else
312 m_aPageSize.setWidth( nValue2 );
313 m_aPageSize.setHeight( nValue1 );
316 sal_Int32 nTextSize = static_cast< sal_Int32 >(m_bRubyUserValue ?
317 m_nRubyUserValue :
318 m_xTextSizeMF->denormalize(m_xTextSizeMF->get_value(FieldUnit::TWIP)));
320 if ( m_bSquaredMode )
322 sal_Int32 nCharsPerLine = m_aPageSize.Width() / nTextSize;
323 m_xCharsPerLineNF->set_max(nCharsPerLine);
324 m_xCharsPerLineNF->set_sensitive(nCharsPerLine != 0);
325 m_xCharsPerLineNF->set_value(nCharsPerLine);
326 sal_Int32 nMaxLines = m_aPageSize.Height() /
327 ( m_xTextSizeMF->denormalize(m_xTextSizeMF->get_value(FieldUnit::TWIP)) +
328 m_xRubySizeMF->denormalize(m_xRubySizeMF->get_value(FieldUnit::TWIP)));
329 m_xLinesPerPageNF->set_max(nMaxLines);
330 m_xLinesPerPageNF->set_sensitive(nMaxLines != 0);
331 SetLinesOrCharsRanges( *m_xCharsRangeFT , m_xCharsPerLineNF->get_max() );
332 SetLinesOrCharsRanges( *m_xLinesRangeFT , m_xLinesPerPageNF->get_max() );
334 else
336 sal_Int32 nTextWidth = static_cast< sal_Int32 >(m_xCharWidthMF->denormalize(m_xCharWidthMF->get_value(FieldUnit::TWIP)));
337 m_xLinesPerPageNF->set_value(m_aPageSize.Height() / nTextSize);
338 if (nTextWidth)
339 m_xCharsPerLineNF->set_value(m_aPageSize.Width() / nTextWidth);
340 else
341 m_xCharsPerLineNF->set_value(45);
342 SetLinesOrCharsRanges( *m_xCharsRangeFT , m_xCharsPerLineNF->get_max() );
343 SetLinesOrCharsRanges( *m_xLinesRangeFT , m_xLinesPerPageNF->get_max() );
347 void SwTextGridPage::SetLinesOrCharsRanges(weld::Label& rField, const sal_Int32 nValue )
349 OUString aFieldStr = "( 1 -" + OUString::number(nValue) + " )";
350 rField.set_label(aFieldStr);
353 const WhichRangesContainer & SwTextGridPage::GetRanges()
355 static const auto gRanges = WhichRangesContainer(svl::Items<RES_TEXTGRID, RES_TEXTGRID>);
356 return gRanges;
359 IMPL_LINK(SwTextGridPage, CharorLineChangedHdl, weld::SpinButton&, rField, void)
361 //if in squared mode
362 if ( m_bSquaredMode )
364 if (m_xCharsPerLineNF.get() == &rField)
366 auto nValue = m_xCharsPerLineNF->get_value();
367 assert(nValue && "div-by-zero");
368 auto nWidth = m_aPageSize.Width() / nValue;
369 m_xTextSizeMF->set_value(m_xTextSizeMF->normalize(nWidth), FieldUnit::TWIP);
370 //prevent rounding errors in the MetricField by saving the used value
371 m_nRubyUserValue = nWidth;
372 m_bRubyUserValue = true;
375 //set maximum line per page
377 sal_Int32 nMaxLines = static_cast< sal_Int32 >(m_aPageSize.Height() /
378 ( m_xTextSizeMF->denormalize(m_xTextSizeMF->get_value(FieldUnit::TWIP)) +
379 m_xRubySizeMF->denormalize(m_xRubySizeMF->get_value(FieldUnit::TWIP))));
380 m_xLinesPerPageNF->set_max(nMaxLines);
381 m_xLinesPerPageNF->set_sensitive(nMaxLines != 0);
383 SetLinesOrCharsRanges( *m_xLinesRangeFT , m_xLinesPerPageNF->get_max() );
384 SetLinesOrCharsRanges( *m_xCharsRangeFT , m_xCharsPerLineNF->get_max() );
386 else//in normal mode
388 if (m_xLinesPerPageNF.get() == &rField)
390 auto nValue = m_xLinesPerPageNF->get_value();
391 assert(nValue && "div-by-zero");
392 auto nHeight = m_aPageSize.Height() / nValue;
393 m_xTextSizeMF->set_value(m_xTextSizeMF->normalize(nHeight), FieldUnit::TWIP);
394 SetLinesOrCharsRanges( *m_xLinesRangeFT , m_xLinesPerPageNF->get_max() );
396 m_nRubyUserValue = nHeight;
397 m_bRubyUserValue = true;
399 else if (m_xCharsPerLineNF.get() == &rField)
401 auto nValue = m_xCharsPerLineNF->get_value();
402 assert(nValue && "div-by-zero");
403 auto nWidth = m_aPageSize.Width() / nValue;
404 m_xCharWidthMF->set_value(m_xCharWidthMF->normalize(nWidth), FieldUnit::TWIP);
405 SetLinesOrCharsRanges( *m_xCharsRangeFT , m_xCharsPerLineNF->get_max() );
408 GridModifyHdl();
411 IMPL_LINK(SwTextGridPage, TextSizeChangedHdl, weld::MetricSpinButton&, rField, void)
413 //if in squared mode
414 if( m_bSquaredMode )
416 if (m_xTextSizeMF.get() == &rField)
418 m_bRubyUserValue = false;
420 // fdo#50941: set maximum characters per line
421 sal_Int32 nTextSize = static_cast< sal_Int32 >(m_xTextSizeMF->denormalize(m_xTextSizeMF->get_value(FieldUnit::TWIP)));
422 if (nTextSize > 0)
424 sal_Int32 nMaxChars = m_aPageSize.Width() / nTextSize;
425 m_xCharsPerLineNF->set_value(nMaxChars);
426 m_xCharsPerLineNF->set_max(nMaxChars);
427 m_xCharsPerLineNF->set_sensitive(nMaxChars != 0);
428 SetLinesOrCharsRanges( *m_xCharsRangeFT , m_xCharsPerLineNF->get_max() );
431 //set maximum line per page
433 sal_Int32 nMaxLines = static_cast< sal_Int32 >(m_aPageSize.Height() /
434 ( m_xTextSizeMF->denormalize(m_xTextSizeMF->get_value(FieldUnit::TWIP)) +
435 m_xRubySizeMF->denormalize(m_xRubySizeMF->get_value(FieldUnit::TWIP))));
436 m_xLinesPerPageNF->set_max(nMaxLines);
437 m_xLinesPerPageNF->set_sensitive(nMaxLines != 0);
438 SetLinesOrCharsRanges( *m_xLinesRangeFT , m_xLinesPerPageNF->get_max() );
441 else
443 if (m_xTextSizeMF.get() == &rField)
445 sal_Int32 nTextSize = static_cast< sal_Int32 >(m_xTextSizeMF->denormalize(m_xTextSizeMF->get_value(FieldUnit::TWIP)));
446 m_xLinesPerPageNF->set_value(m_aPageSize.Height() / nTextSize);
447 m_bRubyUserValue = false;
448 SetLinesOrCharsRanges( *m_xLinesRangeFT , m_xLinesPerPageNF->get_max() );
450 else if (m_xCharWidthMF.get() == &rField)
452 sal_Int32 nTextWidth = static_cast< sal_Int32 >(m_xCharWidthMF->denormalize(m_xCharWidthMF->get_value(FieldUnit::TWIP)));
453 sal_Int32 nMaxChar = 45 ;
454 if (nTextWidth)
455 nMaxChar = m_aPageSize.Width() / nTextWidth;
456 m_xCharsPerLineNF->set_value( nMaxChar );
457 SetLinesOrCharsRanges( *m_xCharsRangeFT , m_xCharsPerLineNF->get_max() );
459 //rubySize is disabled
461 GridModifyHdl();
464 IMPL_LINK(SwTextGridPage, GridTypeHdl, weld::Toggleable&, rButton, void)
466 if (!rButton.get_active())
467 return;
469 if (m_xNoGridRB.get() == &rButton)
471 // GRID_NONE mode:
472 // "Layout" and "Display" sections should all be disabled.
473 m_xLayoutFL->set_sensitive(false);
474 m_xDisplayFL->set_sensitive(false);
476 else
478 // GRID_LINES_ONLY or GRID_LINES_CHARS mode:
479 // "Layout" and "Display" sections should all be enabled;
480 // DisplayGridHdl should be executed;
481 m_xLayoutFL->set_sensitive(true);
482 m_xDisplayFL->set_sensitive(true);
483 DisplayGridHdl(*m_xDisplayCB);
486 if (m_xCharsGridRB.get() == &rButton)
488 // GRID_LINES_CHARS mode:
489 // "Snap to character" should be enabled;
490 // "Characters per line" should be enabled;
491 // "Characters range" should be enabled;
492 m_xSnapToCharsCB->set_sensitive(true);
493 m_xCharsPerLineFT->set_sensitive(true);
494 m_xCharsPerLineNF->set_sensitive(true);
495 m_xCharsRangeFT->set_sensitive(true);
496 m_xCharWidthFT->set_sensitive(true);
497 m_xCharWidthMF->set_sensitive(true);
499 else
501 // GRID_NONE or GRID_LINES_ONLY mode:
502 // "Snap to character" should be disabled;
503 // "Characters per line" should be disabled;
504 // "Characters range" should be disabled;
505 m_xSnapToCharsCB->set_sensitive(false);
506 m_xCharsPerLineFT->set_sensitive(false);
507 m_xCharsPerLineNF->set_sensitive(false);
508 m_xCharsRangeFT->set_sensitive(false);
509 m_xCharWidthFT->set_sensitive(false);
510 m_xCharWidthMF->set_sensitive(false);
513 if (m_xNoGridRB.get() != &rButton)
515 // GRID_LINES_ONLY or GRID_LINES_CHARS mode: (additionally)
516 // TextSizeChangedHdl should be executed to recalculate which dependencies are sensitive.
517 TextSizeChangedHdl(*m_xTextSizeMF);
520 GridModifyHdl();
523 IMPL_LINK_NOARG(SwTextGridPage, DisplayGridHdl, weld::Toggleable&, void)
525 bool bChecked = m_xDisplayCB->get_active();
526 m_xPrintCB->set_sensitive(bChecked);
527 m_xPrintCB->set_active(bChecked);
530 IMPL_LINK_NOARG(SwTextGridPage, GridModifyClickHdl, weld::Toggleable&, void)
532 GridModifyHdl();
535 IMPL_LINK_NOARG(SwTextGridPage, ColorModifyHdl, ColorListBox&, void)
537 GridModifyHdl();
540 void SwTextGridPage::GridModifyHdl()
542 const SfxItemSet& rOldSet = GetItemSet();
543 SfxItemSet aSet(rOldSet);
544 const SfxItemSet* pExSet = GetDialogExampleSet();
545 if(pExSet)
546 aSet.Put(*pExSet);
547 PutGridItem(aSet);
548 m_aExampleWN.UpdateExample(aSet);
551 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */