/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #ifndef __com_sun_star_ui_dialogs_XFilePicker_idl__ #define __com_sun_star_ui_dialogs_XFilePicker_idl__ #ifndef __com_sun_star_lang_IllegalArgumentException_idl__ #include #endif #ifndef __com_sun_star_uno_XInterface_idl__ #include #endif #ifndef __com_sun_star_ui_dialogs_XExecutableDialog_idl__ #include #endif //============================================================================= module com { module sun { module star { module ui { module dialogs { //============================================================================= /** Specifies an interface for a FilePicker */ published interface XFilePicker: com::sun::star::ui::dialogs::XExecutableDialog { //------------------------------------------------------------------------- /** Enable/disable multiselection mode

If the multiselection mode is enabled, multiple files may be selected by the user else only one file selection at a time is possible

@param bMode

A value of enables the multiselection mode.

A value of disables the multiselection mode, this is the default.

*/ void setMultiSelectionMode( [in] boolean bMode ); //------------------------------------------------------------------------- /** Sets the default string that appears in the file name box of a FilePicker. @param aName

Specifies the default file name, displayed when the FilePicker is shown. The implementation may accept any string, and does not have to check for a valid file name or if the file really exists.

*/ void setDefaultName( [in] string aName ); //------------------------------------------------------------------------- /** Sets the directory that the file dialog initially displays. @param aDirectory Specifies the initial directory in URL format. The given URL must be conform to Rfc1738). @throws com::sun::star::lang::IllegalArgumentException if the URL is invalid (doesn't conform to Rfc1738). */ void setDisplayDirectory( [in] string aDirectory ) raises( ::com::sun::star::lang::IllegalArgumentException ); //------------------------------------------------------------------------- /** Returns the directory that the file dialog is currently showing or was last showing before closing the dialog with Ok. If the user did cancel the dialog, the returned value is undefined. @returns The directory in URL format, must be conform to Rfc1738. */ string getDisplayDirectory(); //------------------------------------------------------------------------- /** Returns a sequence of the selected files including path information in URL format, conform to Rfc1738.

If the user closed the dialog with cancel an empty sequence will be returned.


If the dialog is in execution mode and a single file is selected the complete URL of this file will be returned.

If the dialog is in execution mode and multiple files are selected an empty sequence will be returned.

If the dialog is in execution mode and the selected file name is false or any other error occurs an empty sequence will be returned.

@returns

The complete path of the file or directory currently selected in URL format. There are two different cases:

  1. Multiselection is disabled: The first and only entry of the sequence contains the complete path/filename in URL format.
  2. Multiselection is enabled: If only one file is selected, the first entry of the sequence contains the complete path/filename in URL format. If multiple files are selected, the first entry of the sequence contains the path in URL format, and the other entries contains the names of the selected files without path information.

Notes for the implementation of a FileSave dialog:If there exists a checkbox "Automatic File Extension" which is checked and a valid filter is currently selected the dialog may automatically add an extension to the selected file name.

*/ sequence< string > getFiles(); }; //============================================================================= }; }; }; }; }; #endif