/usr/share/webbrowser-app/webcontainer/ContentPickerDialog.qml is in webapp-container 0.23+16.04.20160413-0ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | /*
* Copyright 2014-2015 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 "../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 (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()
}
}
}
|