1*c45d927aSAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*c45d927aSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*c45d927aSAndrew Rist * or more contributor license agreements. See the NOTICE file 5*c45d927aSAndrew Rist * distributed with this work for additional information 6*c45d927aSAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*c45d927aSAndrew Rist * to you under the Apache License, Version 2.0 (the 8*c45d927aSAndrew Rist * "License"); you may not use this file except in compliance 9*c45d927aSAndrew Rist * with the License. You may obtain a copy of the License at 10*c45d927aSAndrew Rist * 11*c45d927aSAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*c45d927aSAndrew Rist * 13*c45d927aSAndrew Rist * Unless required by applicable law or agreed to in writing, 14*c45d927aSAndrew Rist * software distributed under the License is distributed on an 15*c45d927aSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*c45d927aSAndrew Rist * KIND, either express or implied. See the License for the 17*c45d927aSAndrew Rist * specific language governing permissions and limitations 18*c45d927aSAndrew Rist * under the License. 19*c45d927aSAndrew Rist * 20*c45d927aSAndrew Rist *************************************************************/ 21*c45d927aSAndrew Rist 22*c45d927aSAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir #ifndef SD_VIEW_CLIPBOARD_HXX 25cdf0e10cSrcweir #define SD_VIEW_CLIPBOARD_HXX 26cdf0e10cSrcweir 27cdf0e10cSrcweir #include <tools/solar.h> 28cdf0e10cSrcweir 29cdf0e10cSrcweir class SdPage; 30cdf0e10cSrcweir class SdTransferable; 31cdf0e10cSrcweir 32cdf0e10cSrcweir namespace sd { 33cdf0e10cSrcweir 34cdf0e10cSrcweir class View; 35cdf0e10cSrcweir 36cdf0e10cSrcweir 37cdf0e10cSrcweir /** Handle clipboard related tasks for the draw view. 38cdf0e10cSrcweir */ 39cdf0e10cSrcweir class ViewClipboard 40cdf0e10cSrcweir { 41cdf0e10cSrcweir public: 42cdf0e10cSrcweir ViewClipboard (::sd::View& rView); 43cdf0e10cSrcweir virtual ~ViewClipboard (void); 44cdf0e10cSrcweir 45cdf0e10cSrcweir /** Handle the drop of a drag-and-drop action where the transferable 46cdf0e10cSrcweir contains a set of pages. 47cdf0e10cSrcweir */ 48cdf0e10cSrcweir virtual void HandlePageDrop (const SdTransferable& rTransferable); 49cdf0e10cSrcweir 50cdf0e10cSrcweir protected: 51cdf0e10cSrcweir ::sd::View& mrView; 52cdf0e10cSrcweir 53cdf0e10cSrcweir /** Return the first master page of the given transferable. When the 54cdf0e10cSrcweir bookmark list of the transferable contains at least one non-master 55cdf0e10cSrcweir page then NULL is returned. 56cdf0e10cSrcweir */ 57cdf0e10cSrcweir SdPage* GetFirstMasterPage (const SdTransferable& rTransferable); 58cdf0e10cSrcweir 59cdf0e10cSrcweir /** Assign the (first) master page of the given transferable to the 60cdf0e10cSrcweir (...) slide. 61cdf0e10cSrcweir */ 62cdf0e10cSrcweir virtual void AssignMasterPage ( 63cdf0e10cSrcweir const SdTransferable& rTransferable, 64cdf0e10cSrcweir SdPage* pMasterPage); 65cdf0e10cSrcweir 66cdf0e10cSrcweir /** Return an index of a page after which the pages of the transferable 67cdf0e10cSrcweir are to be inserted into the target document. 68cdf0e10cSrcweir */ 69cdf0e10cSrcweir virtual sal_uInt16 DetermineInsertPosition ( 70cdf0e10cSrcweir const SdTransferable& rTransferable); 71cdf0e10cSrcweir 72cdf0e10cSrcweir /** Insert the slides in the given transferable behind the last selected 73cdf0e10cSrcweir slide or, when the selection is empty, behind the last slide. 74cdf0e10cSrcweir @param rTransferable 75cdf0e10cSrcweir This transferable defines which pages to insert. 76cdf0e10cSrcweir @param nInsertPosition 77cdf0e10cSrcweir The pages of the transferable will be inserted behind the page 78cdf0e10cSrcweir with this index. 79cdf0e10cSrcweir @return 80cdf0e10cSrcweir Returns the number of inserted slides. 81cdf0e10cSrcweir */ 82cdf0e10cSrcweir virtual sal_uInt16 InsertSlides ( 83cdf0e10cSrcweir const SdTransferable& rTransferable, 84cdf0e10cSrcweir sal_uInt16 nInsertPosition); 85cdf0e10cSrcweir }; 86cdf0e10cSrcweir 87cdf0e10cSrcweir } // end of namespace ::sd 88cdf0e10cSrcweir 89cdf0e10cSrcweir #endif 90