1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
/*
* Copyright 2014-2016 Canonical Ltd.
*
* This file is part of webbrowser-app.
*
* webbrowser-app is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 3.
*
* webbrowser-app 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
import QtQuick 2.4
import Ubuntu.Components 1.3
import Ubuntu.Components.Popups 1.3 as Popups
import Ubuntu.Content 1.3
import com.canonical.Oxide 1.8
import "../MimeTypeMapper.js" as MimeTypeMapper
import ".."
Component {
Popups.PopupBase {
id: picker
objectName: "contentPickerDialog"
// Set the parent at construction time, instead of letting show()
// set it later on, which for some reason results in the size of
// the dialog not being updated.
parent: QuickUtils.rootItem(this)
property var activeTransfer
Rectangle {
anchors.fill: parent
ContentTransferHint {
anchors.fill: parent
activeTransfer: picker.activeTransfer
}
ContentPeerPicker {
id: peerPicker
anchors.fill: parent
visible: true
contentType: ContentType.All
handler: ContentHandler.Source
onPeerSelected: {
if (peer.appId == "webbrowser-app") {
// If we're inside the browser and the user has
// requested content from the browser then we
// need to handle the transfer internally
var downloadsPage = picker.WebView.view.showDownloadsPage()
downloadsPage.mimetypeFilter = MimeTypeMapper.mimeTypeRegexForContentType(contentType)
downloadsPage.multiSelect = model.allowMultipleFiles
downloadsPage.selectMode = false
downloadsPage.pickingMode = true
downloadsPage.internalFilePicker = model
Popups.PopupUtils.close(picker)
} else {
if (model.allowMultipleFiles) {
peer.selectionType = ContentTransfer.Multiple
} else {
peer.selectionType = ContentTransfer.Single
}
picker.activeTransfer = peer.request()
stateChangeConnection.target = picker.activeTransfer
}
}
onCancelPressed: {
model.reject()
}
}
}
Connections {
id: stateChangeConnection
target: null
onStateChanged: {
if (picker.activeTransfer.state === ContentTransfer.Charged) {
var selectedItems = []
for(var i in picker.activeTransfer.items) {
selectedItems.push(String(picker.activeTransfer.items[i].url).replace("file://", ""))
}
model.accept(selectedItems)
}
}
}
Component.onCompleted: {
if(acceptTypes.length === 1) {
var contentType = MimeTypeMapper.mimeTypeToContentType(acceptTypes[0])
if(contentType == ContentType.Unknown) {
// If we don't recognise the type, allow uploads from any app
contentType = ContentType.All
}
peerPicker.contentType = contentType
} else {
peerPicker.contentType = ContentType.All
}
show()
}
}
}
|