mirror of
https://gitlab.linphone.org/BC/public/linphone-desktop.git
synced 2026-01-21 21:58:06 +00:00
195 lines
No EOL
5.2 KiB
QML
195 lines
No EOL
5.2 KiB
QML
import QtQuick 2.15
|
|
import QtQuick.Effects
|
|
import QtQuick.Layouts
|
|
import QtQuick.Controls as Control
|
|
import Linphone
|
|
import UtilsCpp 1.0
|
|
|
|
ColumnLayout {
|
|
id: mainItem
|
|
spacing: 10 * DefaultStyle.dp
|
|
property string title
|
|
property string validateButtonText
|
|
property string placeHolderText: qsTr("Rechercher des contacts")
|
|
property color titleColor: DefaultStyle.main2_700
|
|
property list<string> selectedParticipants: contactList.selectedContacts
|
|
property int selectedParticipantsCount: selectedParticipants.length
|
|
property alias titleLayout: titleLayout
|
|
property ConferenceInfoGui conferenceInfoGui
|
|
property bool nameGroupCall: false
|
|
readonly property string groupName: groupCallName.text
|
|
signal returnRequested()
|
|
signal validateRequested()
|
|
// Layout.preferredWidth: 362 * DefaultStyle.dp
|
|
|
|
function clearSelectedParticipants() {
|
|
contactList.selectedContacts.clear()
|
|
}
|
|
|
|
RowLayout {
|
|
id: titleLayout
|
|
Layout.fillWidth: true
|
|
Button {
|
|
background: Item{}
|
|
icon.source: AppIcons.leftArrow
|
|
contentImageColor: DefaultStyle.main1_500_main
|
|
Layout.preferredWidth: 24 * DefaultStyle.dp
|
|
Layout.preferredHeight: 24 * DefaultStyle.dp
|
|
icon.width: 24 * DefaultStyle.dp
|
|
icon.height: 24 * DefaultStyle.dp
|
|
onClicked: mainItem.returnRequested()
|
|
}
|
|
ColumnLayout {
|
|
spacing: 0
|
|
Text {
|
|
text: mainItem.title
|
|
color: mainItem.titleColor
|
|
maximumLineCount: 1
|
|
font {
|
|
pixelSize: 18 * DefaultStyle.dp
|
|
weight: 800 * DefaultStyle.dp
|
|
}
|
|
Layout.fillWidth: true
|
|
}
|
|
Text {
|
|
text: qsTr("%1 participant%2 sélectionné").arg(mainItem.selectedParticipantsCount).arg(mainItem.selectedParticipantsCount > 1 ? "s" : "")
|
|
color: DefaultStyle.main2_500main
|
|
maximumLineCount: 1
|
|
font {
|
|
pixelSize: 12 * DefaultStyle.dp
|
|
weight: 300 * DefaultStyle.dp
|
|
}
|
|
Layout.fillWidth: true
|
|
}
|
|
}
|
|
Button {
|
|
Layout.preferredWidth: 70 * DefaultStyle.dp
|
|
topPadding: 6 * DefaultStyle.dp
|
|
bottomPadding: 6 * DefaultStyle.dp
|
|
enabled: contactList.selectedContacts.length != 0
|
|
// leftPadding: 12 * DefaultStyle.dp
|
|
// rightPadding: 12 * DefaultStyle.dp
|
|
text: mainItem.validateButtonText
|
|
textSize: 13 * DefaultStyle.dp
|
|
onClicked: {
|
|
mainItem.validateRequested()
|
|
}
|
|
}
|
|
}
|
|
ColumnLayout {
|
|
visible: mainItem.nameGroupCall
|
|
spacing: 0
|
|
RowLayout {
|
|
Text {
|
|
font.pixelSize: 13 * DefaultStyle.dp
|
|
font.weight: 700 * DefaultStyle.dp
|
|
text: qsTr("Nom du groupe")
|
|
}
|
|
Item{Layout.fillWidth: true}
|
|
Text {
|
|
font.pixelSize: 12 * DefaultStyle.dp
|
|
font.weight: 300 * DefaultStyle.dp
|
|
text: qsTr("Requis")
|
|
}
|
|
}
|
|
TextField {
|
|
id: groupCallName
|
|
Layout.fillWidth: true
|
|
Layout.preferredHeight: 49 * DefaultStyle.dp
|
|
}
|
|
}
|
|
ListView {
|
|
id: participantList
|
|
Layout.fillWidth: true
|
|
// Layout.fillHeight: true
|
|
Layout.preferredHeight: contentHeight
|
|
Layout.maximumHeight: mainItem.height / 3
|
|
width: mainItem.width
|
|
model: contactList.selectedContacts
|
|
clip: true
|
|
delegate: Item {
|
|
height: 56 * DefaultStyle.dp
|
|
width: participantList.width
|
|
RowLayout {
|
|
anchors.fill: parent
|
|
Avatar {
|
|
Layout.preferredWidth: 45 * DefaultStyle.dp
|
|
Layout.preferredHeight: 45 * DefaultStyle.dp
|
|
address: modelData
|
|
}
|
|
Text {
|
|
property var nameObj: UtilsCpp.getDisplayName(modelData)
|
|
text: nameObj ? nameObj.value : ""
|
|
font.pixelSize: 14 * DefaultStyle.dp
|
|
font.capitalization: Font.Capitalize
|
|
}
|
|
Item {
|
|
Layout.fillWidth: true
|
|
}
|
|
Button {
|
|
Layout.preferredWidth: 24 * DefaultStyle.dp
|
|
Layout.preferredHeight: 24 * DefaultStyle.dp
|
|
background: Item{}
|
|
icon.source: AppIcons.closeX
|
|
icon.width: 24 * DefaultStyle.dp
|
|
icon.height: 24 * DefaultStyle.dp
|
|
contentImageColor: DefaultStyle.main1_500_main
|
|
onClicked: contactList.selectedContacts.splice(index, 1)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
SearchBar {
|
|
id: searchbar
|
|
Layout.fillWidth: true
|
|
placeholderText: mainItem.placeHolderText
|
|
}
|
|
Text {
|
|
text: qsTr("Contacts")
|
|
font {
|
|
pixelSize: 16 * DefaultStyle.dp
|
|
weight: 800 * DefaultStyle.dp
|
|
}
|
|
}
|
|
ContactsList {
|
|
id: contactList
|
|
visible: contentHeight > 0 || searchbar.text.length > 0
|
|
Layout.fillWidth: true
|
|
Layout.fillHeight: true
|
|
Layout.preferredHeight: contentHeight
|
|
multiSelectionEnabled: true
|
|
contactMenuVisible: false
|
|
confInfoGui: mainItem.conferenceInfoGui
|
|
searchBarText: searchbar.text
|
|
onContactAddedToSelection: participantList.positionViewAtEnd()
|
|
headerPositioning: ListView.InlineHeader
|
|
header: MouseArea {
|
|
onClicked: contactList.addContactToSelection(sipAddr.text)
|
|
visible: searchbar.text.length > 0
|
|
height: searchbar.text.length > 0 ? 56 * DefaultStyle.dp : 0
|
|
width: contactList.width
|
|
RowLayout {
|
|
Layout.fillWidth: true
|
|
spacing: 10 * DefaultStyle.dp
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.leftMargin: 30 * DefaultStyle.dp
|
|
anchors.left: parent.left
|
|
Avatar {
|
|
Layout.preferredWidth: 45 * DefaultStyle.dp
|
|
Layout.preferredHeight: 45 * DefaultStyle.dp
|
|
address: sipAddr.text
|
|
}
|
|
ColumnLayout {
|
|
Text {
|
|
id: sipAddr
|
|
text: UtilsCpp.generateLinphoneSipAddress(searchbar.text)
|
|
font.pixelSize: 14 * DefaultStyle.dp
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
Item {
|
|
Layout.fillHeight: true
|
|
}
|
|
} |