aboutsummaryrefslogblamecommitdiffstats
path: root/shell/Evolution-ShellComponentDnd.idl
blob: 37322e85dbd04763b556657a185459e9c23b20ff (plain) (tree)
1
2
3
4
5
6
7

                                                                             

                                                                            

           
                                         




















                                                                                       
                             




                                       
                                                  
                                



                                                  























                                                                              

                                                                              


                                                         
                                                       
                                


                                                  




                                                                             

                                                                        

                                                                     
                                                                   



                                                                          

                                                                   





                                                     
/* -*- Mode: IDL; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/*
 * Interface for the Evolution components that want to support Drag and Drop
 * operations on their folders.
 *
 * Authors:
 *   Ettore Perazzoli <ettore@ximian.com>
 *
 * Copyright (C) 2001 Ximian, Inc.
 */

#include <Bonobo.h>

module GNOME {
module Evolution {
module ShellComponentDnd {
    typedef short Action;
    const Action ACTION_DEFAULT = 0;
    const Action ACTION_COPY = 1 << 1;
    const Action ACTION_MOVE = 1 << 2;
    const Action ACTION_LINK = 1 << 3;
    const Action ACTION_ASK = 1 << 4;
    const Action ACTION_ANY = ACTION_COPY | ACTION_MOVE | ACTION_LINK | ACTION_ASK;

    typedef Action ActionSet; // For readability.

    struct Data {
        short format;
        short target;
        sequence <octet> bytes;
    };

    exception NoData {};

    interface SourceFolder : Bonobo::Unknown {
        struct Context {
            string physicalUri;
            string folderType;
            ActionSet possibleActions;
            Action suggestedAction;
        };

        /* The user started a drag from this object.  If the component
           receives this while still in the middle of an existing drag
           operation, it should stop the existing drag operation and
           start a new one.  */
        void beginDrag (in string physical_uri,
                in string folder_type,
                out ActionSet possible_actions,
                out Action suggested_action);

        /* User released the mouse button and dropped the object
           somewhere, so we now want to get the data for the current
           context.  */
        void getData (in Context source_context,
                  in Action action,
                  in string dnd_type,
                  out Data data)
            raises (NoData);

        /* The target has finished processing the data, so we can
           delete it.  */
        void deleteData (in Context source_context);

        /* The drag is over.  This should also clean up the data if
           there was a `getData()' but no `deleteData()' after it.  */
        void endDrag (in Context source_context);
    };

    interface DestinationFolder : Bonobo::Unknown {
        struct Context {
            string dndType;
            ActionSet possibleActions;
            Action suggestedAction;
        };

        /* The user is moving a dragged object over our folder.  This
           will return %FALSE if the specified object cannot be
           dropped; otherwise, it will return %TRUE and then set the
           @default_action and @non_default_action we want to be
           performed when the drop happens.  */
        boolean handleMotion (in string physical_uri,
                      in Context destination_context,
                      out Action suggested_action);

        /* Data is dropped.  We are given the data for the dropped
           object, and we are supposed to perform the operation
           requested.  */
        boolean handleDrop (in string physical_uri,
                    in Context destination_context,
                    in Action action,
                    in Data data);
    };
};
};
};