bump product version to 6.3.0.0.beta1
[LibreOffice.git] / sd / source / ui / slidesorter / inc / controller / SlsSelectionManager.hxx
blobde65f7fce44d6ccc03bbd1e9e535905f548efec3
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 #ifndef INCLUDED_SD_SOURCE_UI_SLIDESORTER_INC_CONTROLLER_SLSSELECTIONMANAGER_HXX
21 #define INCLUDED_SD_SOURCE_UI_SLIDESORTER_INC_CONTROLLER_SLSSELECTIONMANAGER_HXX
23 #include <sal/types.h>
24 #include <tools/link.hxx>
25 #include <vector>
26 #include <memory>
28 class SdPage;
30 namespace sd { namespace slidesorter {
31 class SlideSorter;
32 } }
34 namespace sd { namespace slidesorter { namespace controller {
36 class SlideSorterController;
37 class SelectionObserver;
39 /** This class is a part of the controller and handles the selection of
40 slides.
41 <p>It has methods to modify the selected slides (delete them or
42 move them to other places in the document), change the visible area so
43 to make the selected slides visible, tell listeners when the selection
44 changes.</p>
46 class SelectionManager
48 public:
49 /** Create a new SelectionManger for the given slide sorter.
51 SelectionManager (SlideSorter& rSlideSorter);
53 ~SelectionManager();
55 /** Delete the currently selected slides. When this method returns the
56 selection is empty.
57 @param bSelectFollowingPage
58 When <TRUE/> then after deleting the selected pages make the
59 slide after the last selected page the new current page.
60 When <FALSE/> then make the first slide before the selected
61 pages the new current slide.
63 void DeleteSelectedPages (const bool bSelectFollowingPage = true);
65 /** Call this method after the selection has changed (possible several
66 calls to the PageSelector) to invalidate the relevant slots and send
67 appropriate events.
69 void SelectionHasChanged ();
71 /** Add a listener that is called when the selection of the slide sorter
72 changes.
73 @param rListener
74 When this method is called multiple times for the same listener
75 the second and all following calls are ignored. Each listener
76 is added only once.
78 void AddSelectionChangeListener (const Link<LinkParamNone*,void>& rListener);
80 /** Remove a listener that was called when the selection of the slide
81 sorter changes.
82 @param rListener
83 It is safe to pass a listener that was not added are has been
84 removed previously. Such calls are ignored.
86 void RemoveSelectionChangeListener (const Link<LinkParamNone*,void>& rListener);
88 /** Return the position where to insert pasted slides based on the
89 current selection. When there is a selection then the insert
90 position is behind the last slide. When the selection is empty then
91 most of the time the insert position is at the end of the document.
92 There is an exception right after the display of a popup-menu. The
93 position of the associated insertion marker is stored here and reset
94 the next time the selection changes.
96 sal_Int32 GetInsertionPosition() const;
98 /** Store an insertion position temporarily. It is reset when the
99 selection changes the next time.
101 void SetInsertionPosition (const sal_Int32 nInsertionPosition);
103 const std::shared_ptr<SelectionObserver>& GetSelectionObserver() const { return mpSelectionObserver;}
105 private:
106 SlideSorter& mrSlideSorter;
107 SlideSorterController& mrController;
109 ::std::vector<Link<LinkParamNone*,void>> maSelectionChangeListeners;
111 /** The insertion position is only temporarily valid. Negative values
112 indicate that the explicit insertion position is not valid. In this
113 case GetInsertionPosition() calculates it from the current selection.
115 sal_Int32 mnInsertionPosition;
117 std::shared_ptr<SelectionObserver> mpSelectionObserver;
119 /** Delete the given list of normal pages. This method is a helper
120 function for DeleteSelectedPages().
121 @param rSelectedNormalPages
122 A list of normal pages. Supplying master pages is an error.
124 void DeleteSelectedNormalPages (const ::std::vector<SdPage*>& rSelectedNormalPages);
126 /** Delete the given list of master pages. This method is a helper
127 function for DeleteSelectedPages().
128 @param rSelectedMasterPages
129 A list of master pages. Supplying normal pages is an error.
131 void DeleteSelectedMasterPages (const ::std::vector<SdPage*>& rSelectedMasterPages);
134 } } } // end of namespace ::sd::slidesorter::controller
136 #endif
138 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */