2013-02-17 11:35:20 -08:00
|
|
|
# Copyright (C) 2007-2013 various contributors (see AUTHORS)
|
|
|
|
#
|
|
|
|
# This file is part of Python-EFL.
|
|
|
|
#
|
|
|
|
# Python-EFL 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.
|
|
|
|
#
|
|
|
|
# Python-EFL 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 Python-EFL. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
.. rubric:: Fileselector modes
|
|
|
|
|
|
|
|
.. data:: ELM_FILESELECTOR_LIST
|
|
|
|
|
|
|
|
Layout as a list
|
|
|
|
|
|
|
|
.. data:: ELM_FILESELECTOR_GRID
|
|
|
|
|
|
|
|
Layout as a grid
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
include "widget_header.pxi"
|
2013-02-22 04:00:26 -08:00
|
|
|
include "callback_conversions.pxi"
|
2013-02-17 11:35:20 -08:00
|
|
|
|
|
|
|
from layout_class cimport LayoutClass
|
|
|
|
|
|
|
|
cimport enums
|
|
|
|
|
|
|
|
ELM_FILESELECTOR_LIST = enums.ELM_FILESELECTOR_LIST
|
|
|
|
ELM_FILESELECTOR_GRID = enums.ELM_FILESELECTOR_GRID
|
|
|
|
|
|
|
|
cdef class Fileselector(LayoutClass):
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
A file selector is a widget that allows a user to navigate through a
|
|
|
|
file system, reporting file selections back via its API.
|
|
|
|
|
|
|
|
It contains shortcut buttons for home directory (*~*) and to jump one
|
|
|
|
directory upwards (..), as well as cancel/ok buttons to confirm/cancel a
|
|
|
|
given selection. After either one of those two former actions, the file
|
|
|
|
selector will issue its ``"done"`` smart callback.
|
|
|
|
|
|
|
|
There's a text entry on it, too, showing the name of the current
|
|
|
|
selection. There's the possibility of making it editable, so it is
|
|
|
|
useful on file saving dialogs on applications, where one gives a file
|
|
|
|
name to save contents to, in a given directory in the system. This
|
|
|
|
custom file name will be reported on the ``"done"`` smart callback
|
|
|
|
(explained in sequence).
|
|
|
|
|
|
|
|
Finally, it has a view to display file system items into in two possible
|
|
|
|
forms:
|
|
|
|
|
|
|
|
- list
|
|
|
|
- grid
|
|
|
|
|
|
|
|
If Elementary is built with support of the Ethumb thumbnailing library,
|
|
|
|
the second form of view will display preview thumbnails of files which
|
|
|
|
it supports.
|
|
|
|
|
|
|
|
This widget emits the following signals, besides the ones sent from
|
|
|
|
:py:class:`elementary.layout.Layout`:
|
|
|
|
|
|
|
|
- ``"selected"`` - the user has clicked on a file (when not in
|
|
|
|
folders-only mode) or directory (when in folders-only mode)
|
|
|
|
- ``"directory,open"`` - the list has been populated with new
|
|
|
|
content (*event_info* is the directory's path)
|
|
|
|
- ``"done"`` - the user has clicked on the "ok" or "cancel"
|
|
|
|
buttons (*event_info* is the selection's path)
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
cdef object _cbs
|
|
|
|
|
|
|
|
def __init__(self, evasObject parent):
|
|
|
|
self._set_obj(elm_fileselector_add(parent.obj))
|
|
|
|
self._cbs = {}
|
|
|
|
|
|
|
|
property is_save:
|
|
|
|
"""Enable/disable the file name entry box where the user can type
|
|
|
|
in a name for a file, in a given file selector widget
|
|
|
|
|
|
|
|
Having the entry editable is useful on file saving dialogs on
|
|
|
|
applications, where one gives a file name to save contents to,
|
|
|
|
in a given directory in the system. This custom file name will
|
|
|
|
be reported on the ``"done"`` smart callback.
|
|
|
|
|
|
|
|
:type: bool
|
|
|
|
|
|
|
|
"""
|
|
|
|
def __get__(self):
|
|
|
|
return elm_fileselector_is_save_get(self.obj)
|
|
|
|
|
|
|
|
def __set__(self, is_save):
|
|
|
|
elm_fileselector_is_save_set(self.obj, is_save)
|
|
|
|
|
|
|
|
def is_save_set(self, is_save):
|
|
|
|
elm_fileselector_is_save_set(self.obj, is_save)
|
|
|
|
def is_save_get(self):
|
|
|
|
return elm_fileselector_is_save_get(self.obj)
|
|
|
|
|
|
|
|
property folder_only:
|
|
|
|
"""Enable/disable folder-only view for a given file selector widget
|
|
|
|
|
|
|
|
If enabled, the widget's view will only display folder items,
|
|
|
|
naturally.
|
|
|
|
|
|
|
|
:type: bool
|
|
|
|
|
|
|
|
"""
|
|
|
|
def __get__(self):
|
|
|
|
return elm_fileselector_folder_only_get(self.obj)
|
|
|
|
|
|
|
|
def __set__(self, folder_only):
|
|
|
|
elm_fileselector_folder_only_set(self.obj, folder_only)
|
|
|
|
|
|
|
|
def folder_only_set(self, folder_only):
|
|
|
|
elm_fileselector_folder_only_set(self.obj, folder_only)
|
|
|
|
def folder_only_get(self):
|
|
|
|
return elm_fileselector_folder_only_get(self.obj)
|
|
|
|
|
|
|
|
property buttons_ok_cancel:
|
|
|
|
"""Enable/disable the "ok" and "cancel" buttons on a given file
|
|
|
|
selector widget
|
|
|
|
|
|
|
|
.. note:: A file selector without those buttons will never emit the
|
|
|
|
``"done"`` smart event, and is only usable if one is just hooking
|
|
|
|
to the other two events.
|
|
|
|
|
|
|
|
:type: bool
|
|
|
|
|
|
|
|
"""
|
|
|
|
def __get__(self):
|
|
|
|
return elm_fileselector_buttons_ok_cancel_get(self.obj)
|
|
|
|
|
|
|
|
def __set__(self, buttons):
|
|
|
|
elm_fileselector_buttons_ok_cancel_set(self.obj, buttons)
|
|
|
|
|
|
|
|
def buttons_ok_cancel_set(self, buttons):
|
|
|
|
elm_fileselector_buttons_ok_cancel_set(self.obj, buttons)
|
|
|
|
def buttons_ok_cancel_get(self):
|
|
|
|
return elm_fileselector_buttons_ok_cancel_get(self.obj)
|
|
|
|
|
|
|
|
property expandable:
|
|
|
|
"""Enable/disable a tree view in the given file selector widget,
|
|
|
|
**if it's in** ``ELM_FILESELECTOR_LIST`` **mode**
|
|
|
|
|
|
|
|
In a tree view, arrows are created on the sides of directories,
|
|
|
|
allowing them to expand in place.
|
|
|
|
|
|
|
|
.. note:: If it's in other mode, the changes made by this function
|
|
|
|
will only be visible when one switches back to "list" mode.
|
|
|
|
|
|
|
|
:type: bool
|
|
|
|
|
|
|
|
"""
|
|
|
|
def __get__(self):
|
|
|
|
return elm_fileselector_expandable_get(self.obj)
|
|
|
|
|
|
|
|
def __set__(self, expand):
|
|
|
|
elm_fileselector_expandable_set(self.obj, expand)
|
|
|
|
|
|
|
|
def expandable_set(self, expand):
|
|
|
|
elm_fileselector_expandable_set(self.obj, expand)
|
|
|
|
def expandable_get(self):
|
|
|
|
return elm_fileselector_expandable_get(self.obj)
|
|
|
|
|
|
|
|
property path:
|
|
|
|
"""The **directory** that a given file selector widget will display
|
|
|
|
contents from
|
|
|
|
|
|
|
|
Setting this will change the **directory** displayed. It
|
|
|
|
will also clear the text entry area on the object, which
|
|
|
|
displays select files' names.
|
|
|
|
|
|
|
|
:type: string
|
|
|
|
|
|
|
|
"""
|
|
|
|
def __get__(self):
|
2013-04-02 04:35:20 -07:00
|
|
|
return self.path_get()
|
2013-02-17 11:35:20 -08:00
|
|
|
|
|
|
|
def __set__(self, path):
|
2013-04-02 04:35:20 -07:00
|
|
|
self.path_set(path)
|
2013-02-17 11:35:20 -08:00
|
|
|
|
2013-04-02 04:35:20 -07:00
|
|
|
cpdef path_set(self, path):
|
|
|
|
if isinstance(path, unicode): path = path.encode("UTF-8")
|
|
|
|
elm_fileselector_path_set(self.obj,
|
|
|
|
<const_char *>path if path is not None else NULL)
|
|
|
|
cpdef path_get(self):
|
2013-02-17 11:35:20 -08:00
|
|
|
return _ctouni(elm_fileselector_path_get(self.obj))
|
|
|
|
|
|
|
|
property selected:
|
|
|
|
"""The currently selected file/directory in the given file selector
|
|
|
|
widget
|
|
|
|
|
|
|
|
:type: string
|
|
|
|
|
|
|
|
"""
|
|
|
|
def __get__(self):
|
2013-04-02 04:35:20 -07:00
|
|
|
return self.selected_get()
|
2013-02-17 11:35:20 -08:00
|
|
|
|
|
|
|
def __set__(self, path):
|
2013-04-02 04:35:20 -07:00
|
|
|
self.selected_set(path)
|
2013-02-17 11:35:20 -08:00
|
|
|
|
2013-04-02 04:35:20 -07:00
|
|
|
cpdef selected_set(self, path):
|
|
|
|
if isinstance(path, unicode): path = path.encode("UTF-8")
|
|
|
|
if not elm_fileselector_selected_set(self.obj,
|
|
|
|
<const_char *>path if path is not None else NULL):
|
|
|
|
raise RuntimeError("Setting the selected path failed")
|
|
|
|
cpdef selected_get(self):
|
2013-02-17 11:35:20 -08:00
|
|
|
return _ctouni(elm_fileselector_selected_get(self.obj))
|
|
|
|
|
|
|
|
property mode:
|
|
|
|
"""The mode in which a given file selector widget will display
|
|
|
|
(layout) file system entries in its view
|
|
|
|
|
|
|
|
.. note:: By using :py:attr:`expandable`, the user may
|
|
|
|
trigger a tree view for that list.
|
|
|
|
|
|
|
|
.. note:: If Elementary is built with support of the Ethumb
|
|
|
|
thumbnailing library, the second form of view will display
|
|
|
|
preview thumbnails of files which it supports. You must have
|
|
|
|
elm_need_ethumb() called in your Elementary for thumbnailing to
|
|
|
|
work, though.
|
|
|
|
|
|
|
|
.. seealso:: :py:attr:`expandable`
|
|
|
|
|
|
|
|
:type: Elm_Fileselector_Mode
|
|
|
|
|
|
|
|
"""
|
|
|
|
def __get__(self):
|
|
|
|
return elm_fileselector_mode_get(self.obj)
|
|
|
|
|
|
|
|
def __set__(self, mode):
|
|
|
|
elm_fileselector_mode_set(self.obj, mode)
|
|
|
|
|
|
|
|
def mode_set(self, mode):
|
|
|
|
elm_fileselector_mode_set(self.obj, mode)
|
|
|
|
def mode_get(self):
|
|
|
|
return elm_fileselector_mode_get(self.obj)
|
|
|
|
|
|
|
|
def callback_selected_add(self, func, *args, **kwargs):
|
|
|
|
"""The user has clicked on a file (when not in folders-only mode) or
|
|
|
|
directory (when in folders-only mode). Parameter ``event_info``
|
|
|
|
contains the selected file or directory."""
|
|
|
|
self._callback_add_full("selected", _cb_string_conv,
|
|
|
|
func, *args, **kwargs)
|
|
|
|
|
|
|
|
def callback_selected_del(self, func):
|
|
|
|
self._callback_del_full("selected", _cb_string_conv, func)
|
|
|
|
|
|
|
|
def callback_directory_open_add(self, func, *args, **kwargs):
|
|
|
|
"""The list has been populated with new content (*event_info* is
|
|
|
|
the directory's path)."""
|
|
|
|
self._callback_add_full("directory,open", _cb_string_conv,
|
|
|
|
func, *args, **kwargs)
|
|
|
|
|
|
|
|
def callback_directory_open_del(self, func):
|
|
|
|
self._callback_del_full("directory,open", _cb_string_conv, func)
|
|
|
|
|
|
|
|
def callback_done_add(self, func, *args, **kwargs):
|
|
|
|
"""The user has clicked on the "ok" or "cancel" buttons
|
|
|
|
(*event_info* is a pointer to the selection's path)."""
|
|
|
|
self._callback_add_full("done", _cb_string_conv,
|
|
|
|
func, *args, **kwargs)
|
|
|
|
|
|
|
|
def callback_done_del(self, func):
|
|
|
|
self._callback_del_full("done", _cb_string_conv, func)
|
|
|
|
|
|
|
|
|
|
|
|
_object_mapping_register("elm_fileselector", Fileselector)
|