Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
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/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
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 .
18 : */
19 :
20 : #include <uielement/toolbarmerger.hxx>
21 : #include <uielement/generictoolbarcontroller.hxx>
22 : #include <framework/imageproducer.hxx>
23 :
24 : #include <svtools/miscopt.hxx>
25 : #include <comphelper/processfactory.hxx>
26 :
27 : namespace framework
28 : {
29 :
30 : static const char MERGE_TOOLBAR_URL[] = "URL";
31 : static const char MERGE_TOOLBAR_TITLE[] = "Title";
32 : static const char MERGE_TOOLBAR_IMAGEID[] = "ImageIdentifier";
33 : static const char MERGE_TOOLBAR_CONTEXT[] = "Context";
34 : static const char MERGE_TOOLBAR_TARGET[] = "Target";
35 : static const char MERGE_TOOLBAR_CONTROLTYPE[] = "ControlType";
36 : static const char MERGE_TOOLBAR_WIDTH[] = "Width";
37 :
38 : static const char MERGECOMMAND_ADDAFTER[] = "AddAfter";
39 : static const char MERGECOMMAND_ADDBEFORE[] = "AddBefore";
40 : static const char MERGECOMMAND_REPLACE[] = "Replace";
41 : static const char MERGECOMMAND_REMOVE[] = "Remove";
42 :
43 : static const char MERGEFALLBACK_ADDLAST[] = "AddLast";
44 : static const char MERGEFALLBACK_ADDFIRST[] = "AddFirst";
45 : static const char MERGEFALLBACK_IGNORE[] = "Ignore";
46 :
47 : static const char TOOLBARCONTROLLER_BUTTON[] = "Button";
48 : static const char TOOLBARCONTROLLER_COMBOBOX[] = "Combobox";
49 : static const char TOOLBARCONTROLLER_EDIT[] = "Editfield";
50 : static const char TOOLBARCONTROLLER_SPINFIELD[] = "Spinfield";
51 : static const char TOOLBARCONTROLLER_IMGBUTTON[] = "ImageButton";
52 : static const char TOOLBARCONTROLLER_DROPDOWNBOX[] = "Dropdownbox";
53 : static const char TOOLBARCONTROLLER_DROPDOWNBTN[] = "DropdownButton";
54 : static const char TOOLBARCONTROLLER_TOGGLEDDBTN[] = "ToggleDropdownButton";
55 :
56 : static const char TOOLBOXITEM_SEPARATOR_STR[] = "private:separator";
57 :
58 : using namespace ::com::sun::star;
59 :
60 : /**
61 : Check whether a module identifier is part of a context
62 : defined by a colon separated list of module identifier.
63 :
64 : @param
65 : rContext
66 :
67 : Describes a context string list where all contexts
68 : are delimited by a colon. For more information about
69 : the module identifier used as context strings see the
70 : IDL description of com::sun::star::frame::XModuleManager
71 :
72 : @param
73 : rModuleIdentifier
74 :
75 : A string describing a module identifier. See IDL
76 : description of com::sun::star::frame::XModuleManager.
77 :
78 : @result
79 : The result is true if the rContext is an empty string
80 : or rModuleIdentifier is part of the context string.
81 :
82 : */
83 0 : bool ToolBarMerger::IsCorrectContext(
84 : const OUString& rContext,
85 : const OUString& rModuleIdentifier )
86 : {
87 0 : return ( rContext.isEmpty() || ( rContext.indexOf( rModuleIdentifier ) >= 0 ));
88 : }
89 :
90 : /**
91 : Converts a sequence, sequence of property values to
92 : a vector of structs.
93 :
94 : @param
95 : rSequence
96 :
97 : Provides a sequence, sequence of property values.
98 :
99 : @param
100 : rContainer
101 :
102 : A vector of AddonToolbarItems which will hold the
103 : conversion from the rSequence argument.
104 :
105 : @result
106 : The result is true if the sequence, sequence of property
107 : values could be converted to a vector of structs.
108 :
109 : */
110 0 : bool ToolBarMerger::ConvertSeqSeqToVector(
111 : const uno::Sequence< uno::Sequence< beans::PropertyValue > > rSequence,
112 : AddonToolbarItemContainer& rContainer )
113 : {
114 0 : sal_Int32 nLen( rSequence.getLength() );
115 0 : for ( sal_Int32 i = 0; i < nLen; i++ )
116 : {
117 0 : AddonToolbarItem aAddonToolbarItem;
118 0 : ConvertSequenceToValues( rSequence[i],
119 : aAddonToolbarItem.aCommandURL,
120 : aAddonToolbarItem.aLabel,
121 : aAddonToolbarItem.aImageIdentifier,
122 : aAddonToolbarItem.aTarget,
123 : aAddonToolbarItem.aContext,
124 : aAddonToolbarItem.aControlType,
125 0 : aAddonToolbarItem.nWidth );
126 0 : rContainer.push_back( aAddonToolbarItem );
127 0 : }
128 :
129 0 : return true;
130 : }
131 :
132 : /**
133 : Converts a sequence of property values to single
134 : values.
135 :
136 : @param
137 : rSequence
138 :
139 : Provides a sequence of property values.
140 :
141 : @param
142 : rCommandURL
143 :
144 : Contains the value of the property with
145 : Name="CommandURL".
146 :
147 : @param
148 : rLabel
149 :
150 : Contains the value of the property with
151 : Name="Title"
152 :
153 : @param
154 : rImageIdentifier
155 :
156 : Contains the value of the property with
157 : Name="ImageIdentifier"
158 :
159 : @param
160 : rTarget
161 :
162 : Contains the value of the property with
163 : Name="Target"
164 :
165 : @param
166 : rContext
167 :
168 : Contains the value of the property with
169 : Name="Context"
170 :
171 : @param
172 : rControlType
173 :
174 : Contains the value of the property with
175 : Name="ControlType"
176 :
177 : @result
178 : All possible mapping between sequence of property
179 : values and the single values are done.
180 :
181 : */
182 0 : void ToolBarMerger::ConvertSequenceToValues(
183 : const uno::Sequence< beans::PropertyValue > rSequence,
184 : OUString& rCommandURL,
185 : OUString& rLabel,
186 : OUString& rImageIdentifier,
187 : OUString& rTarget,
188 : OUString& rContext,
189 : OUString& rControlType,
190 : sal_uInt16& rWidth )
191 : {
192 0 : for ( sal_Int32 i = 0; i < rSequence.getLength(); i++ )
193 : {
194 0 : if ( rSequence[i].Name == MERGE_TOOLBAR_URL )
195 0 : rSequence[i].Value >>= rCommandURL;
196 0 : else if ( rSequence[i].Name == MERGE_TOOLBAR_TITLE )
197 0 : rSequence[i].Value >>= rLabel;
198 0 : else if ( rSequence[i].Name == MERGE_TOOLBAR_IMAGEID )
199 0 : rSequence[i].Value >>= rImageIdentifier;
200 0 : else if ( rSequence[i].Name == MERGE_TOOLBAR_CONTEXT )
201 0 : rSequence[i].Value >>= rContext;
202 0 : else if ( rSequence[i].Name == MERGE_TOOLBAR_TARGET )
203 0 : rSequence[i].Value >>= rTarget;
204 0 : else if ( rSequence[i].Name == MERGE_TOOLBAR_CONTROLTYPE )
205 0 : rSequence[i].Value >>= rControlType;
206 0 : else if ( rSequence[i].Name == MERGE_TOOLBAR_WIDTH )
207 : {
208 0 : sal_Int32 aValue = 0;
209 0 : rSequence[i].Value >>= aValue;
210 0 : rWidth = sal_uInt16( aValue );
211 : }
212 : }
213 0 : }
214 :
215 : /**
216 : Tries to find the reference point provided and delivers
217 : position and result of the search process.
218 :
219 : @param
220 : pToolbar
221 :
222 : Must be a valid pointer to a toolbar with items which
223 : should be searched.
224 :
225 : @param
226 : rReferencePoint
227 :
228 : A command URL which should be the reference point for
229 : the coming merge operation.
230 :
231 : @result
232 : Provides information about the search result, the
233 : position of the reference point and the toolbar used.
234 : */
235 0 : ReferenceToolbarPathInfo ToolBarMerger::FindReferencePoint(
236 : ToolBox* pToolbar,
237 : const OUString& rReferencePoint )
238 : {
239 : ReferenceToolbarPathInfo aResult;
240 0 : aResult.bResult = false;
241 0 : aResult.pToolbar = pToolbar;
242 0 : aResult.nPos = TOOLBOX_ITEM_NOTFOUND;
243 :
244 0 : const sal_uInt16 nSize( pToolbar->GetItemCount() );
245 :
246 0 : for ( sal_uInt16 i = 0; i < nSize; i++ )
247 : {
248 0 : const sal_uInt16 nItemId = pToolbar->GetItemId( i );
249 0 : if ( nItemId > 0 )
250 : {
251 0 : const OUString rCmd = pToolbar->GetItemCommand( nItemId );
252 0 : if ( rCmd == rReferencePoint )
253 : {
254 0 : aResult.bResult = true;
255 0 : aResult.nPos = i;
256 0 : return aResult;
257 0 : }
258 : }
259 : }
260 :
261 0 : return aResult;
262 : }
263 :
264 : /**
265 : Processes a merge operation.
266 :
267 : @param
268 : xFrame
269 :
270 : Must be a valid reference to a frame.
271 :
272 : @param
273 : pToolbar
274 :
275 : A valid pointer to the toolbar where the merge
276 : operation is applied to.
277 :
278 : @param
279 : nPos
280 :
281 : The reference position of the toolbar item for
282 : the merge operation. Value must be between
283 : 0 and number of toolbar items - 1.
284 :
285 : @param
286 : rItemId
287 :
288 : A unique item ID.
289 :
290 : @param
291 : rModuleIdentifier
292 :
293 : The current application module context.
294 :
295 : @param
296 : rMergeCommand
297 :
298 : A merge command.
299 :
300 : @param
301 : rMergeCommandParameter.
302 :
303 : An optional argument for the merge command.
304 :
305 : @param
306 : rItems
307 :
308 : Toolbar items which are associated to the merge
309 : command.
310 :
311 : @result
312 : Returns true for a successful operation otherwise
313 : false.
314 : */
315 0 : bool ToolBarMerger::ProcessMergeOperation(
316 : const uno::Reference< frame::XFrame >& xFrame,
317 : ToolBox* pToolbar,
318 : sal_uInt16 nPos,
319 : sal_uInt16& rItemId,
320 : CommandToInfoMap& rCommandMap,
321 : const OUString& rModuleIdentifier,
322 : const OUString& rMergeCommand,
323 : const OUString& rMergeCommandParameter,
324 : const AddonToolbarItemContainer& rItems )
325 : {
326 0 : if ( rMergeCommand == MERGECOMMAND_ADDAFTER )
327 0 : return MergeItems( xFrame, pToolbar, nPos, 1, rItemId, rCommandMap, rModuleIdentifier, rItems );
328 0 : else if ( rMergeCommand == MERGECOMMAND_ADDBEFORE )
329 0 : return MergeItems( xFrame, pToolbar, nPos, 0, rItemId, rCommandMap, rModuleIdentifier, rItems );
330 0 : else if ( rMergeCommand == MERGECOMMAND_REPLACE )
331 0 : return ReplaceItem( xFrame, pToolbar, nPos, rItemId, rCommandMap, rModuleIdentifier, rItems );
332 0 : else if ( rMergeCommand == MERGECOMMAND_REMOVE )
333 0 : return RemoveItems( pToolbar, nPos, rMergeCommandParameter );
334 :
335 0 : return false;
336 : }
337 :
338 : /**
339 : Processes a merge fallback operation.
340 :
341 : @param
342 : xFrame
343 :
344 : Must be a valid reference to a frame.
345 :
346 : @param
347 : pToolbar
348 :
349 : A valid pointer to the toolbar where the merge
350 : fall back operation is applied to.
351 :
352 : @param
353 : nPos
354 :
355 : The reference position of the toolbar item for
356 : the merge operation. Value must be between
357 : 0 and number of toolbar items - 1.
358 :
359 : @param
360 : rItemId
361 :
362 : A unique item ID.
363 :
364 : @param
365 : rModuleIdentifier
366 :
367 : The current application module context.
368 :
369 : @param
370 : rMergeCommand
371 :
372 : A merge command.
373 :
374 : @param
375 : rItems
376 :
377 : Toolbar items which are associated to the merge
378 : command.
379 :
380 : @result
381 : Returns true for a successful operation otherwise
382 : false.
383 : */
384 0 : bool ToolBarMerger::ProcessMergeFallback(
385 : const ::com::sun::star::uno::Reference< ::com::sun::star::frame::XFrame >& xFrame,
386 : ToolBox* pToolbar,
387 : sal_uInt16 /*nPos*/,
388 : sal_uInt16& rItemId,
389 : CommandToInfoMap& rCommandMap,
390 : const OUString& rModuleIdentifier,
391 : const OUString& rMergeCommand,
392 : const OUString& rMergeFallback,
393 : const AddonToolbarItemContainer& rItems )
394 : {
395 0 : if (( rMergeFallback == MERGEFALLBACK_IGNORE ) ||
396 0 : ( rMergeCommand == MERGECOMMAND_REPLACE ) ||
397 0 : ( rMergeCommand == MERGECOMMAND_REMOVE ) )
398 : {
399 0 : return true;
400 : }
401 0 : else if (( rMergeCommand == MERGECOMMAND_ADDBEFORE ) ||
402 0 : ( rMergeCommand == MERGECOMMAND_ADDAFTER ) )
403 : {
404 0 : if ( rMergeFallback == MERGEFALLBACK_ADDFIRST )
405 0 : return MergeItems( xFrame, pToolbar, 0, 0, rItemId, rCommandMap, rModuleIdentifier, rItems );
406 0 : else if ( rMergeFallback == MERGEFALLBACK_ADDLAST )
407 0 : return MergeItems( xFrame, pToolbar, TOOLBOX_APPEND, 0, rItemId, rCommandMap, rModuleIdentifier, rItems );
408 : }
409 :
410 0 : return false;
411 : }
412 :
413 : /**
414 : Merges (adds) toolbar items into an existing toolbar.
415 :
416 : @param
417 : xFrame
418 :
419 : Must be a valid reference to a frame.
420 :
421 : @param
422 : pToolbar
423 :
424 : A valid pointer to the toolbar where the merge
425 : fall back operation is applied to.
426 :
427 : @param
428 : nPos
429 :
430 : The reference position of the toolbar item for
431 : the merge operation. Value must be between
432 : 0 and number of toolbar items - 1.
433 :
434 : @param
435 : rItemId
436 :
437 : A unique item ID.
438 :
439 : @param
440 : rModuleIdentifier
441 :
442 : The current application module context.
443 :
444 : @param
445 : rItems
446 :
447 : Toolbar items which are associated to the merge
448 : command.
449 :
450 : @result
451 : Returns true for a successful operation otherwise
452 : false.
453 : */
454 0 : bool ToolBarMerger::MergeItems(
455 : const uno::Reference< frame::XFrame >& rFrame,
456 : ToolBox* pToolbar,
457 : sal_uInt16 nPos,
458 : sal_uInt16 nModIndex,
459 : sal_uInt16& rItemId,
460 : CommandToInfoMap& rCommandMap,
461 : const OUString& rModuleIdentifier,
462 : const AddonToolbarItemContainer& rAddonToolbarItems )
463 : {
464 0 : const sal_Int32 nSize( rAddonToolbarItems.size() );
465 :
466 0 : uno::Reference< frame::XFrame > xFrame( rFrame );
467 :
468 0 : sal_uInt16 nIndex( 0 );
469 0 : for ( sal_Int32 i = 0; i < nSize; i++ )
470 : {
471 0 : const AddonToolbarItem& rItem = rAddonToolbarItems[i];
472 0 : if ( IsCorrectContext( rItem.aContext, rModuleIdentifier ))
473 : {
474 0 : sal_Int32 nInsPos = nPos+nModIndex+i;
475 0 : if ( nInsPos > sal_Int32( pToolbar->GetItemCount() ))
476 0 : nInsPos = TOOLBOX_APPEND;
477 :
478 0 : if ( rItem.aCommandURL == TOOLBOXITEM_SEPARATOR_STR )
479 0 : pToolbar->InsertSeparator( sal_uInt16( nInsPos ));
480 : else
481 : {
482 0 : CommandToInfoMap::iterator pIter = rCommandMap.find( rItem.aCommandURL );
483 0 : if ( pIter == rCommandMap.end())
484 : {
485 0 : CommandInfo aCmdInfo;
486 0 : aCmdInfo.nId = rItemId;
487 0 : const CommandToInfoMap::value_type aValue( rItem.aCommandURL, aCmdInfo );
488 0 : rCommandMap.insert( aValue );
489 : }
490 : else
491 : {
492 0 : pIter->second.aIds.push_back( rItemId );
493 : }
494 :
495 0 : ToolBarMerger::CreateToolbarItem( pToolbar, rCommandMap, sal_uInt16( nInsPos ), rItemId, rItem );
496 : }
497 :
498 0 : ++nIndex;
499 0 : ++rItemId;
500 : }
501 : }
502 :
503 0 : return true;
504 : }
505 :
506 : /**
507 : Replaces a toolbar item with new items for an
508 : existing toolbar.
509 :
510 : @param
511 : xFrame
512 :
513 : Must be a valid reference to a frame.
514 :
515 : @param
516 : pToolbar
517 :
518 : A valid pointer to the toolbar where the merge
519 : fall back operation is applied to.
520 :
521 : @param
522 : nPos
523 :
524 : The reference position of the toolbar item for
525 : the merge operation. Value must be between
526 : 0 and number of toolbar items - 1.
527 :
528 : @param
529 : rItemId
530 :
531 : A unique item ID.
532 :
533 : @param
534 : rModuleIdentifier
535 :
536 : The current application module context.
537 :
538 : @param
539 : rItems
540 :
541 : Toolbar items which are associated to the merge
542 : command.
543 :
544 : @result
545 : Returns true for a successful operation otherwise
546 : false.
547 : */
548 0 : bool ToolBarMerger::ReplaceItem(
549 : const uno::Reference< frame::XFrame >& xFrame,
550 : ToolBox* pToolbar,
551 : sal_uInt16 nPos,
552 : sal_uInt16& rItemId,
553 : CommandToInfoMap& rCommandMap,
554 : const OUString& rModuleIdentifier,
555 : const AddonToolbarItemContainer& rAddonToolbarItems )
556 : {
557 0 : pToolbar->RemoveItem( nPos );
558 0 : return MergeItems( xFrame, pToolbar, nPos, 0, rItemId, rCommandMap, rModuleIdentifier, rAddonToolbarItems );
559 : }
560 :
561 : /**
562 : Removes toolbar items from an existing toolbar.
563 :
564 : @param
565 : pToolbar
566 :
567 : A valid pointer to the toolbar where the merge
568 : fall back operation is applied to.
569 :
570 : @param
571 : nPos
572 :
573 : The reference position of the toolbar item for
574 : the merge operation. Value must be between
575 : 0 and number of toolbar items - 1.
576 :
577 : @param
578 : rMergeCommandParameter.
579 :
580 : An optional argument for the merge command.
581 :
582 : @result
583 : Returns true for a successful operation otherwise
584 : false.
585 : */
586 0 : bool ToolBarMerger::RemoveItems(
587 : ToolBox* pToolbar,
588 : sal_uInt16 nPos,
589 : const OUString& rMergeCommandParameter )
590 : {
591 0 : sal_Int32 nCount = rMergeCommandParameter.toInt32();
592 0 : if ( nCount > 0 )
593 : {
594 0 : for ( sal_Int32 i = 0; i < nCount; i++ )
595 : {
596 0 : if ( nPos < pToolbar->GetItemCount() )
597 0 : pToolbar->RemoveItem( nPos );
598 : }
599 : }
600 0 : return true;
601 : }
602 :
603 : /**
604 : Removes toolbar items from an existing toolbar.
605 :
606 : @param
607 : pToolbar
608 :
609 : A valid pointer to the toolbar where the merge
610 : fall back operation is applied to.
611 :
612 : @param
613 : nPos
614 :
615 : The reference position of the toolbar item for
616 : the merge operation. Value must be between
617 : 0 and number of toolbar items - 1.
618 :
619 : @param
620 : rMergeCommandParameter.
621 :
622 : An optional argument for the merge command.
623 :
624 : @result
625 : Returns true for a successful operation otherwise
626 : false.
627 : */
628 0 : ::cppu::OWeakObject* ToolBarMerger::CreateController(
629 : const uno::Reference< uno::XComponentContext >& rxContext,
630 : const uno::Reference< frame::XFrame > & xFrame,
631 : ToolBox* pToolbar,
632 : const OUString& rCommandURL,
633 : sal_uInt16 nId,
634 : sal_uInt16 nWidth,
635 : const OUString& rControlType )
636 : {
637 0 : ::cppu::OWeakObject* pResult( 0 );
638 :
639 0 : if ( rControlType == TOOLBARCONTROLLER_BUTTON )
640 0 : pResult = new ButtonToolbarController( rxContext, pToolbar, rCommandURL );
641 0 : else if ( rControlType == TOOLBARCONTROLLER_COMBOBOX )
642 0 : pResult = new ComboboxToolbarController( rxContext, xFrame, pToolbar, nId, nWidth, rCommandURL );
643 0 : else if ( rControlType == TOOLBARCONTROLLER_EDIT )
644 0 : pResult = new EditToolbarController( rxContext, xFrame, pToolbar, nId, nWidth, rCommandURL );
645 0 : else if ( rControlType == TOOLBARCONTROLLER_SPINFIELD )
646 0 : pResult = new SpinfieldToolbarController( rxContext, xFrame, pToolbar, nId, nWidth, rCommandURL );
647 0 : else if ( rControlType == TOOLBARCONTROLLER_IMGBUTTON )
648 0 : pResult = new ImageButtonToolbarController( rxContext, xFrame, pToolbar, nId, rCommandURL );
649 0 : else if ( rControlType == TOOLBARCONTROLLER_DROPDOWNBOX )
650 0 : pResult = new DropdownToolbarController( rxContext, xFrame, pToolbar, nId, nWidth, rCommandURL );
651 0 : else if ( rControlType == TOOLBARCONTROLLER_DROPDOWNBTN )
652 : pResult = new ToggleButtonToolbarController( rxContext, xFrame, pToolbar, nId,
653 0 : ToggleButtonToolbarController::STYLE_DROPDOWNBUTTON, rCommandURL );
654 0 : else if ( rControlType == TOOLBARCONTROLLER_TOGGLEDDBTN )
655 : pResult = new ToggleButtonToolbarController( rxContext, xFrame, pToolbar, nId,
656 0 : ToggleButtonToolbarController::STYLE_TOGGLE_DROPDOWNBUTTON, rCommandURL );
657 : else
658 0 : pResult = new GenericToolbarController( rxContext, xFrame, pToolbar, nId, rCommandURL );
659 :
660 0 : return pResult;
661 : }
662 :
663 0 : void ToolBarMerger::CreateToolbarItem( ToolBox* pToolbar, CommandToInfoMap& rCommandMap, sal_uInt16 nPos, sal_uInt16 nItemId, const AddonToolbarItem& rItem )
664 : {
665 0 : pToolbar->InsertItem( nItemId, rItem.aLabel, 0, nPos );
666 0 : pToolbar->SetItemCommand( nItemId, rItem.aCommandURL );
667 0 : pToolbar->SetQuickHelpText( nItemId, rItem.aLabel );
668 0 : pToolbar->SetItemText( nItemId, rItem.aLabel );
669 0 : pToolbar->EnableItem( nItemId, true );
670 0 : pToolbar->SetItemState( nItemId, TRISTATE_FALSE );
671 :
672 0 : CommandToInfoMap::iterator pIter = rCommandMap.find( rItem.aCommandURL );
673 0 : if ( pIter != rCommandMap.end() )
674 0 : pIter->second.nWidth = rItem.nWidth;
675 :
676 : // Use the user data to store add-on specific data with the toolbar item
677 0 : AddonsParams* pAddonParams = new AddonsParams;
678 0 : pAddonParams->aImageId = rItem.aImageIdentifier;
679 0 : pAddonParams->aTarget = rItem.aTarget;
680 0 : pAddonParams->aControlType = rItem.aControlType;
681 0 : pToolbar->SetItemData( nItemId, pAddonParams );
682 0 : }
683 :
684 : } // namespace framework
685 :
686 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|