Files
tdesktop/Telegram/ThirdParty/xdg-desktop-portal/data/org.freedesktop.portal.FileChooser.xml
allhaileris afb81b8278
Some checks failed
Docker. / Ubuntu (push) Has been cancelled
User-agent updater. / User-agent (push) Failing after 15s
Lock Threads / lock (push) Failing after 10s
Waiting for answer. / waiting-for-answer (push) Failing after 22s
Close stale issues and PRs / stale (push) Successful in 13s
Needs user action. / needs-user-action (push) Failing after 8s
Can't reproduce. / cant-reproduce (push) Failing after 8s
init
2026-02-16 15:50:16 +03:00

332 lines
12 KiB
XML

<?xml version="1.0"?>
<!--
Copyright (C) 2015 Red Hat, Inc.
SPDX-License-Identifier: LGPL-2.1-or-later
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library. If not, see <http://www.gnu.org/licenses/>.
Author: Alexander Larsson <alexl@redhat.com>
-->
<node name="/" xmlns:doc="http://www.freedesktop.org/dbus/1.0/doc.dtd">
<!--
org.freedesktop.portal.FileChooser:
@short_description: File chooser portal
The FileChooser portal allows sandboxed applications to ask
the user for access to files outside the sandbox. The portal
backend will present the user with a file chooser dialog.
The selected files will be made accessible to the application
(which may involve adding it to the :ref:`Documents
portal<org.freedesktop.portal.Documents>`).
This documentation describes version 4 of this interface.
-->
<interface name="org.freedesktop.portal.FileChooser">
<!--
OpenFile:
@parent_window: Identifier for the application window, see :doc:`window-identifiers`
@title: Title for the file chooser dialog
@options: Vardict with optional further information
@handle: Object path for the :ref:`org.freedesktop.portal.Request` object representing this call
Asks to open one or more files.
Supported keys in the @options vardict include:
* ``handle_token`` (``s``)
A string that will be used as the last element of the @handle. Must be a valid
object path element. See the :ref:`org.freedesktop.portal.Request` documentation for
more information about the @handle.
* ``accept_label`` (``s``)
Label for the accept button. Mnemonic underlines are allowed.
* ``modal`` (``b``)
Whether the dialog should be modal. Default is true.
* ``multiple`` (``b``)
Whether multiple files can be selected or not. Default is single-selection.
* ``directory`` (``b``)
Whether to select for folders instead of files. Default is to select files.
This option was added in version 3.
* ``filters`` (``a(sa(us))``)
List of serialized file filters.
Each item in the array specifies a single filter to offer to the user.
The first string is a user-visible name for the filter. The ``a(us)``
specifies a list of filter strings, which can be either a glob-style
pattern (indicated by 0) or a MIME type (indicated by 1). Patterns are
case-sensitive.
To match different capitalizations of, e.g. ``'*.ico'``, use a pattern
like: ``'*.[iI][cC][oO]'``.
Example: ``[('Images', [(0, '*.ico'), (1, 'image/png')]), ('Text', [(0, '*.txt')])]``
Note that filters are purely there to aid the user in making a useful
selection. The portal may still allow the user to select files that
don't match any filter criteria, and applications must be prepared to
handle that.
* ``current_filter`` (``(sa(us))``)
Request that this filter be set by default at dialog creation. If
the filters list is nonempty, it should match a filter in the
list to set the default filter from the list. Alternatively, it
may be specified when the list is empty to apply the filter
unconditionally.
* ``choices`` (``a(ssa(ss)s)``)
List of serialized combo boxes to add to the file chooser.
For each element, the first string is an ID that will be returned
with the response, the second string is a user-visible label. The
``a(ss)`` is the list of choices, each being an ID and a
user-visible label. The final string is the initial selection,
or "", to let the portal decide which choice will be initially selected.
None of the strings, except for the initial selection, should be empty.
As a special case, passing an empty array for the list of choices
indicates a boolean choice that is typically displayed as a check
button, using "true" and "false" as the choices.
Example: ``[('encoding', 'Encoding', [('utf8', 'Unicode (UTF-8)'), ('latin15', 'Western')], 'latin15'), ('reencode', 'Reencode', [], 'false')]``
* ``current_folder`` (``ay``)
Suggested folder from which the files should be opened.
The byte array contains a path in the same encoding as the file
system, and it's expected to be terminated by a nul byte.
If the path points to a location in the document storage, it will be
replaced with the path to the location on the host.
The portal implementation is free to ignore this option.
The following results get returned via the :ref:`org.freedesktop.portal.Request::Response` signal:
* ``uris`` (``as``)
An array of strings containing the uris of the selected files. All URIs
have the ``file://`` scheme.
* ``choices`` (``a(ss)``)
An array of pairs of strings, the first string being the ID of a
combobox that was passed into this call, the second string being
the selected option.
Example: ``[('encoding', 'utf8'), ('reencode', 'true')]``
* ``current_filter`` (``(sa(us))``)
The filter that was selected. This may match a filter in the
filter list or another filter that was applied unconditionally.
-->
<method name="OpenFile">
<arg type="s" name="parent_window" direction="in"/>
<arg type="s" name="title" direction="in"/>
<annotation name="org.qtproject.QtDBus.QtTypeName.In2" value="QVariantMap"/>
<arg type="a{sv}" name="options" direction="in"/>
<arg type="o" name="handle" direction="out"/>
</method>
<!--
SaveFile:
@parent_window: Identifier for the application window, see :doc:`window-identifiers`
@title: Title for the file chooser dialog
@options: Vardict with optional further information
@handle: Object path for the :ref:`org.freedesktop.portal.Request` object representing this call
Asks for a location to save a file.
Supported keys in the @options vardict include:
* ``handle_token`` (``s``)
A string that will be used as the last element of the @handle. Must be a valid
object path element. See the :ref:`org.freedesktop.portal.Request` documentation for
more information about the @handle.
* ``accept_label`` (``s``)
Label for the accept button. Mnemonic underlines are allowed.
* ``modal`` (``b``)
Whether the dialog should be modal. Default is yes.
* ``filters`` (``a(sa(us))``)
List of serialized file filters.
See org.freedesktop.portal.FileChooser.OpenFile() for details.
* ``current_filter`` (``(sa(us))``)
Request that this filter be set by default at dialog creation.
See org.freedesktop.portal.FileChooser.OpenFile() for details.
* ``choices`` (``a(ssa(ss)s)``)
List of serialized combo boxes.
See org.freedesktop.portal.FileChooser.OpenFile() for details.
* ``current_name`` (``s``)
Suggested name of the file.
* ``current_folder`` (``ay``)
Suggested folder in which the file should be saved. The byte array
contains a path in the same encoding as the file system, and it's
expected to be terminated by a nul byte.
If the path points to a location in the document storage, it will be
replaced with the path to the location on the host.
The portal implementation is free to ignore this option.
* ``current_file`` (``ay``)
The current file (when saving an existing file), in the same encoding as the file
system. The byte array is expected to be terminated by a nul byte.
The following results get returned via the :ref:`org.freedesktop.portal.Request::Response` signal:
* ``uris`` (``as``)
An array of strings containing the uri of the selected file. All URIs
have the ``file://`` scheme.
* ``choices`` (``a(ss)``)
An array of pairs of strings, corresponding to the passed-in choices.
See org.freedesktop.portal.FileChooser.OpenFile() for details.
* ``current_filter`` (``(sa(us))``)
The filter that was selected.
See org.freedesktop.portal.FileChooser.OpenFile() for details.
-->
<method name="SaveFile">
<arg type="s" name="parent_window" direction="in"/>
<arg type="s" name="title" direction="in"/>
<annotation name="org.qtproject.QtDBus.QtTypeName.In2" value="QVariantMap"/>
<arg type="a{sv}" name="options" direction="in"/>
<arg type="o" name="handle" direction="out"/>
</method>
<!--
SaveFiles:
@parent_window: Identifier for the application window, see :doc:`window-identifiers`
@title: Title for the file chooser dialog
@options: Vardict with optional further information
@handle: Object path for the :ref:`org.freedesktop.portal.Request` object representing this call
Asks for a folder as a location to save one or more files. The
names of the files will be used as-is and appended to the
selected folder's path in the list of returned files. If the
selected folder already contains a file with one of the given
names, the portal may prompt or take some other action to
construct a unique file name and return that instead.
Supported keys in the @options vardict include:
* ``handle_token`` (``s``)
A string that will be used as the last element of the
@handle. Must be a valid object path element. See the
:ref:`org.freedesktop.portal.Request` documentation for more
information about the @handle.
* ``accept_label`` (``s``)
Label for the accept button. Mnemonic underlines are allowed.
* ``modal`` (``b``)
Whether the dialog should be modal. Default is yes.
* ``choices`` (``a(ssa(ss)s)``)
List of serialized combo boxes.
See org.freedesktop.portal.FileChooser.OpenFile() for details.
* ``current_folder`` (``ay``)
Suggested folder in which the files should be saved. The byte array
contains a path in the same encoding as the file system, and it's
expected to be terminated by a nul byte.
If the path points to a location in the document storage, it will be
replaced with the path to the location on the host.
The portal implementation is free to ignore this option.
* ``files`` (``aay``)
An array of file names, using the same encoding as the file system,
to be saved. Each byte array is expected to be terminated by a nul
The following results get returned via the
:ref:`org.freedesktop.portal.Request::Response` signal:
* ``uris`` (``as``)
An array of strings containing the uri corresponding to
each file given by @options, in the same order. Note that
the file names may have changed, for example if a file
with the same name in the selected folder already exists.
All URIs have the ``file://`` scheme.
* ``choices`` (``a(ss)``)
An array of pairs of strings, corresponding to the passed-in choices.
See org.freedesktop.portal.FileChooser.OpenFile() for details.
-->
<method name="SaveFiles">
<arg type="s" name="parent_window" direction="in"/>
<arg type="s" name="title" direction="in"/>
<annotation name="org.qtproject.QtDBus.QtTypeName.In2" value="QVariantMap"/>
<arg type="a{sv}" name="options" direction="in"/>
<arg type="o" name="handle" direction="out"/>
</method>
<property name="version" type="u" access="read"/>
</interface>
</node>