mirror of
https://github.com/nomic-ai/gpt4all.git
synced 2024-10-01 01:06:10 -04:00
9273b49b62
Signed-off-by: Adam Treat <treat.adam@gmail.com> Signed-off-by: Jared Van Bortel <jared@nomic.ai> Co-authored-by: Jared Van Bortel <jared@nomic.ai>
149 lines
5.5 KiB
QML
149 lines
5.5 KiB
QML
import QtCore
|
||
import QtQuick
|
||
import QtQuick.Controls
|
||
import QtQuick.Controls.Basic
|
||
import QtQuick.Layouts
|
||
import QtQuick.Dialogs
|
||
import chatlistmodel
|
||
import localdocs
|
||
import llm
|
||
|
||
Rectangle {
|
||
id: collectionsDrawer
|
||
|
||
color: "transparent"
|
||
|
||
signal addDocsClicked
|
||
property var currentChat: ChatListModel.currentChat
|
||
|
||
Rectangle {
|
||
id: borderLeft
|
||
anchors.top: parent.top
|
||
anchors.bottom: parent.bottom
|
||
anchors.left: parent.left
|
||
width: 2
|
||
color: theme.dividerColor
|
||
}
|
||
|
||
ScrollView {
|
||
id: scrollView
|
||
anchors.top: parent.top
|
||
anchors.bottom: parent.bottom
|
||
anchors.left: borderLeft.right
|
||
anchors.right: parent.right
|
||
anchors.margins: 15
|
||
clip: true
|
||
contentHeight: 300
|
||
ScrollBar.vertical.policy: ScrollBar.AlwaysOff
|
||
|
||
ListView {
|
||
id: listView
|
||
model: LocalDocs.localDocsModel
|
||
boundsBehavior: Flickable.StopAtBounds
|
||
ScrollBar.vertical: ScrollBar {
|
||
parent: listView.parent
|
||
anchors.top: listView.top
|
||
anchors.left: listView.right
|
||
anchors.bottom: listView.bottom
|
||
}
|
||
spacing: 15
|
||
|
||
delegate: Rectangle {
|
||
width: listView.width
|
||
height: childrenRect.height + 15
|
||
color: checkBox.checked ? theme.collectionsButtonBackground : "transparent"
|
||
|
||
RowLayout {
|
||
anchors.top: parent.top
|
||
anchors.left: parent.left
|
||
anchors.right: parent.right
|
||
anchors.margins: 7.5
|
||
MyCheckBox {
|
||
id: checkBox
|
||
Layout.alignment: Qt.AlignLeft
|
||
checked: currentChat.hasCollection(collection)
|
||
onClicked: {
|
||
if (checkBox.checked) {
|
||
currentChat.addCollection(collection)
|
||
} else {
|
||
currentChat.removeCollection(collection)
|
||
}
|
||
}
|
||
ToolTip.text: qsTr("Warning: searching collections while indexing can return incomplete results")
|
||
ToolTip.visible: hovered && model.indexing
|
||
}
|
||
ColumnLayout {
|
||
Layout.fillWidth: true
|
||
Layout.alignment: Qt.AlignLeft
|
||
Text {
|
||
Layout.fillWidth: true
|
||
Layout.alignment: Qt.AlignLeft
|
||
text: collection
|
||
font.pixelSize: theme.fontSizeLarger
|
||
elide: Text.ElideRight
|
||
color: theme.textColor
|
||
}
|
||
Text {
|
||
Layout.fillWidth: true
|
||
Layout.alignment: Qt.AlignLeft
|
||
text: "%1 – %2".arg(qsTr("%n file(s)", "", model.totalDocs)).arg(qsTr("%n word(s)", "", model.totalWords))
|
||
elide: Text.ElideRight
|
||
color: theme.mutedTextColor
|
||
font.pixelSize: theme.fontSizeSmaller
|
||
}
|
||
RowLayout {
|
||
visible: model.updating
|
||
Layout.fillWidth: true
|
||
Layout.alignment: Qt.AlignLeft
|
||
MyBusyIndicator {
|
||
color: theme.accentColor
|
||
size: 24
|
||
Layout.minimumWidth: 24
|
||
Layout.minimumHeight: 24
|
||
}
|
||
Text {
|
||
text: qsTr("Updating")
|
||
elide: Text.ElideRight
|
||
color: theme.accentColor
|
||
font.pixelSize: theme.fontSizeSmaller
|
||
font.bold: true
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
footer: ColumnLayout {
|
||
width: listView.width
|
||
spacing: 30
|
||
Rectangle {
|
||
visible: listView.count !== 0
|
||
Layout.topMargin: 30
|
||
Layout.fillWidth: true
|
||
height: 1
|
||
color: theme.dividerColor
|
||
}
|
||
MySettingsButton {
|
||
id: collectionSettings
|
||
enabled: LocalDocs.databaseValid
|
||
Layout.alignment: Qt.AlignCenter
|
||
text: qsTr("\uFF0B Add Docs")
|
||
font.pixelSize: theme.fontSizeLarger
|
||
onClicked: {
|
||
addDocsClicked()
|
||
}
|
||
}
|
||
Text {
|
||
Layout.fillWidth: true
|
||
Layout.alignment: Qt.AlignLeft
|
||
text: qsTr("Chat privately with local files using on-device Large Language Models (LLMs). Keeps data private and secure. Best results with Llama 3 Instruct.")
|
||
font.pixelSize: theme.fontSizeLarger
|
||
wrapMode: Text.WordWrap
|
||
elide: Text.ElideRight
|
||
color: theme.mutedTextColor
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|