summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMicah Lee <micah@micahflee.com>2017-05-22 16:04:56 -0700
committerMicah Lee <micah@micahflee.com>2017-05-22 16:04:56 -0700
commit9385487c105612eefc640d6be64ea89205eb4bc3 (patch)
tree2466263e07bb7aef0b3438b56950b3cc7f0a05a7
parentf01bd30263675d4a50da5257ccb9d9c4b5d7dc6c (diff)
parentd6332c8f959b631fc33c88fb7f2f9a0ffee7940a (diff)
downloadonionshare-9385487c105612eefc640d6be64ea89205eb4bc3.tar.gz
onionshare-9385487c105612eefc640d6be64ea89205eb4bc3.zip
Merge branch 'select_multiple_folders' of https://github.com/mig5/onionshare into mig5-select_multiple_folders
-rw-r--r--onionshare_gui/file_selection.py18
-rw-r--r--share/locale/en.json4
-rw-r--r--share/locale/fr.json4
3 files changed, 18 insertions, 8 deletions
diff --git a/onionshare_gui/file_selection.py b/onionshare_gui/file_selection.py
index 2ebbbb75..0de96e02 100644
--- a/onionshare_gui/file_selection.py
+++ b/onionshare_gui/file_selection.py
@@ -225,10 +225,20 @@ class FileSelection(QtWidgets.QVBoxLayout):
"""
Add folder button clicked.
"""
- filename = QtWidgets.QFileDialog.getExistingDirectory(
- caption=strings._('gui_choose_folder', True), options=QtWidgets.QFileDialog.ReadOnly)
- if filename:
- self.file_list.add_file(str(filename))
+ file_dialog = QtWidgets.QFileDialog(caption=strings._('gui_choose_folder', True))
+ file_dialog.setFileMode(QtWidgets.QFileDialog.Directory)
+ file_dialog.setOption(QtWidgets.QFileDialog.DontUseNativeDialog, True)
+ file_dialog.setOption(QtWidgets.QFileDialog.ReadOnly, True)
+ file_dialog.setOption(QtWidgets.QFileDialog.ShowDirsOnly, True)
+ tree_view = file_dialog.findChild(QtWidgets.QTreeView)
+ tree_view.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
+ list_view = file_dialog.findChild(QtWidgets.QListView, "listView")
+ list_view.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
+
+ if file_dialog.exec_() == QtWidgets.QDialog.Accepted:
+ for filename in file_dialog.selectedFiles():
+ self.file_list.add_file(filename)
+
self.update()
def delete_file(self):
diff --git a/share/locale/en.json b/share/locale/en.json
index 701b067c..754993a2 100644
--- a/share/locale/en.json
+++ b/share/locale/en.json
@@ -24,10 +24,10 @@
"help_filename": "List of files or folders to share",
"gui_drag_and_drop": "Drag and drop\nfiles here",
"gui_add_files": "Add Files",
- "gui_add_folder": "Add Folder",
+ "gui_add_folder": "Add Folders",
"gui_delete": "Delete",
"gui_choose_files": "Choose files",
- "gui_choose_folder": "Choose folder",
+ "gui_choose_folder": "Choose folders",
"gui_start_server": "Start Sharing",
"gui_stop_server": "Stop Sharing",
"gui_copy_url": "Copy URL",
diff --git a/share/locale/fr.json b/share/locale/fr.json
index ce9cfa15..7197f9dc 100644
--- a/share/locale/fr.json
+++ b/share/locale/fr.json
@@ -21,10 +21,10 @@
"help_filename": "Liste des fichiers ou dossiers à partager",
"gui_drag_and_drop": "Glissez déposez\nles fichiers ici",
"gui_add_files": "Ajouter des fichiers",
- "gui_add_folder": "Ajouter un dossier",
+ "gui_add_folder": "Ajouter des dossiers",
"gui_delete": "Supprimer",
"gui_choose_files": "Sélectionnez des fichiers",
- "gui_choose_folder": "Sélectionnez un dossier",
+ "gui_choose_folder": "Sélectionnez des dossiers",
"gui_start_server": "Démarrer le serveur",
"gui_stop_server": "Arrêter le serveur",
"gui_copy_url": "Copier URL",