mirror of
https://github.com/nomic-ai/gpt4all
synced 2024-11-08 07:10:32 +00:00
87 lines
2.4 KiB
QML
87 lines
2.4 KiB
QML
|
import QtCore
|
||
|
import QtQuick
|
||
|
import QtQuick.Controls
|
||
|
import QtQuick.Controls.Basic
|
||
|
import QtQuick.Layouts
|
||
|
import QtQuick.Dialogs
|
||
|
import localdocs
|
||
|
import llm
|
||
|
|
||
|
Dialog {
|
||
|
id: collectionsDialog
|
||
|
modal: true
|
||
|
opacity: 0.9
|
||
|
padding: 20
|
||
|
width: 480
|
||
|
height: 640
|
||
|
|
||
|
property var currentChat: LLM.chatListModel.currentChat
|
||
|
|
||
|
background: Rectangle {
|
||
|
anchors.fill: parent
|
||
|
color: theme.backgroundDarkest
|
||
|
border.width: 1
|
||
|
border.color: theme.dialogBorder
|
||
|
radius: 10
|
||
|
}
|
||
|
|
||
|
Label {
|
||
|
id: listLabel
|
||
|
anchors.top: parent.top
|
||
|
anchors.left: parent.left
|
||
|
text: "Available Collections:"
|
||
|
color: theme.textColor
|
||
|
}
|
||
|
|
||
|
ScrollView {
|
||
|
id: scrollView
|
||
|
anchors.top: listLabel.bottom
|
||
|
anchors.topMargin: 20
|
||
|
anchors.bottom: parent.bottom
|
||
|
anchors.left: parent.left
|
||
|
anchors.right: parent.right
|
||
|
clip: true
|
||
|
contentHeight: 300
|
||
|
ScrollBar.vertical.policy: ScrollBar.AlwaysOn
|
||
|
|
||
|
background: Rectangle {
|
||
|
color: theme.backgroundLighter
|
||
|
}
|
||
|
|
||
|
ListView {
|
||
|
id: listView
|
||
|
model: LocalDocs.localDocsModel
|
||
|
boundsBehavior: Flickable.StopAtBounds
|
||
|
delegate: Rectangle {
|
||
|
id: item
|
||
|
width: listView.width
|
||
|
height: collectionId.height + 40
|
||
|
color: index % 2 === 0 ? theme.backgroundLight : theme.backgroundLighter
|
||
|
MyCheckBox {
|
||
|
id: checkBox
|
||
|
anchors.verticalCenter: parent.verticalCenter
|
||
|
anchors.left: parent.left
|
||
|
anchors.margins: 20
|
||
|
checked: currentChat.hasCollection(collection)
|
||
|
onClicked: {
|
||
|
if (checkBox.checked) {
|
||
|
currentChat.addCollection(collection)
|
||
|
} else {
|
||
|
currentChat.removeCollection(collection)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
Text {
|
||
|
id: collectionId
|
||
|
anchors.verticalCenter: parent.verticalCenter
|
||
|
anchors.left: checkBox.right
|
||
|
anchors.margins: 20
|
||
|
text: collection
|
||
|
elide: Text.ElideRight
|
||
|
color: theme.textColor
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|