Merge branch 'main' of http://101.34.228.45:3000/auto/AicsKnowledgeBase into main
commit
8c37bca675
|
@ -211,7 +211,9 @@ Item {
|
||||||
Rectangle {
|
Rectangle {
|
||||||
id: fileListItemRect
|
id: fileListItemRect
|
||||||
width: ListView.view.width
|
width: ListView.view.width
|
||||||
height: model.isDir ? 50 : 120
|
//set the height to fit model.brief
|
||||||
|
height: model.isDir ? 50 : Math.max(120,
|
||||||
|
model.brief.length / 3 + 80)
|
||||||
//color: !ListView.isCurrentItem ? "white" : "red"
|
//color: !ListView.isCurrentItem ? "white" : "red"
|
||||||
FileListItem {
|
FileListItem {
|
||||||
id: fileListItem
|
id: fileListItem
|
||||||
|
|
|
@ -84,8 +84,16 @@ FluArea {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MouseArea {
|
ColumnLayout {
|
||||||
|
id: row
|
||||||
|
anchors.fill: parent
|
||||||
|
anchors.margins: 10
|
||||||
|
spacing: 10
|
||||||
|
ColumnLayout {
|
||||||
|
id: clickable
|
||||||
anchors.fill: row
|
anchors.fill: row
|
||||||
|
MouseArea {
|
||||||
|
anchors.fill: parent
|
||||||
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
||||||
onDoubleClicked: {
|
onDoubleClicked: {
|
||||||
fileItem.parent.doubleClicked()
|
fileItem.parent.doubleClicked()
|
||||||
|
@ -96,11 +104,6 @@ FluArea {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ColumnLayout {
|
|
||||||
id: clickable
|
|
||||||
anchors.fill: row
|
|
||||||
|
|
||||||
RowLayout {
|
RowLayout {
|
||||||
id: titleRow
|
id: titleRow
|
||||||
Image {
|
Image {
|
||||||
|
@ -124,10 +127,11 @@ FluArea {
|
||||||
visible: !fileItem.isDir
|
visible: !fileItem.isDir
|
||||||
text: fileItem.brief
|
text: fileItem.brief
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
wrapMode: Text.WrapAnywhere
|
wrapMode: Text.WordWrap
|
||||||
elide: Text.ElideRight
|
elide: Text.ElideRight
|
||||||
maximumLineCount: 2
|
maximumLineCount: 4
|
||||||
textFormat: Text.RichText
|
textFormat: Text.RichText
|
||||||
|
fontSizeMode: Text.Fit
|
||||||
}
|
}
|
||||||
RowLayout {
|
RowLayout {
|
||||||
id: infoRow
|
id: infoRow
|
||||||
|
@ -158,13 +162,7 @@ FluArea {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
ColumnLayout {
|
|
||||||
id: row
|
|
||||||
anchors.fill: parent
|
|
||||||
anchors.margins: 10
|
|
||||||
spacing: 10
|
|
||||||
|
|
||||||
RowLayout {
|
RowLayout {
|
||||||
visible: !fileItem.isDir
|
visible: !fileItem.isDir
|
||||||
Repeater {
|
Repeater {
|
||||||
|
@ -181,4 +179,3 @@ FluArea {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
|
@ -4,6 +4,8 @@ import QtQuick.Window
|
||||||
import QtQuick.Controls
|
import QtQuick.Controls
|
||||||
import QtQuick.Controls.Basic
|
import QtQuick.Controls.Basic
|
||||||
import FluentUI
|
import FluentUI
|
||||||
|
import "qrc:///AicsKnowledgeBase/qml/component"
|
||||||
|
import "qrc:///AicsKnowledgeBase/qml/global"
|
||||||
|
|
||||||
FluArea {
|
FluArea {
|
||||||
property string url: ''
|
property string url: ''
|
||||||
|
@ -14,7 +16,72 @@ FluArea {
|
||||||
Layout.topMargin: 20
|
Layout.topMargin: 20
|
||||||
|
|
||||||
FluText {
|
FluText {
|
||||||
|
id: title
|
||||||
Layout.topMargin: 20
|
Layout.topMargin: 20
|
||||||
text: "Favorite"
|
text: "Favourite"
|
||||||
|
}
|
||||||
|
FileList {
|
||||||
|
anchors.top: title.bottom
|
||||||
|
disableHeader: true
|
||||||
|
width: parent.width
|
||||||
|
dataModel: listModel
|
||||||
|
}
|
||||||
|
ListModel {
|
||||||
|
id: listModel
|
||||||
|
}
|
||||||
|
Component.onCompleted: {
|
||||||
|
Request.get("/user", response => {
|
||||||
|
var files = JSON.parse(response).starredKnowledge
|
||||||
|
listModel.clear()
|
||||||
|
for (var i = 0; i < files.length; i++) {
|
||||||
|
var file = files[i]
|
||||||
|
console.log(file.name)
|
||||||
|
var modelItem = {
|
||||||
|
"title": file.knowledge.name,
|
||||||
|
"uuid": file.knowledge.id,
|
||||||
|
"date"// cut time after 'T'
|
||||||
|
: file.knowledge.createTime.substring(0, 10),
|
||||||
|
"fuuid": "0"
|
||||||
|
}
|
||||||
|
modelItem.isDir = false
|
||||||
|
modelItem.type = getType(file.suffix)
|
||||||
|
modelItem.size = file.size
|
||||||
|
modelItem.brief = file.brief
|
||||||
|
modelItem.pageView = file.pageView
|
||||||
|
modelItem.stars = 0
|
||||||
|
var tagString = ""
|
||||||
|
for (var j = 0; j < file.tags.length; j++) {
|
||||||
|
if (j != 0)
|
||||||
|
tagString = tagString + ","
|
||||||
|
tagString = tagString + file.tags[j].name
|
||||||
|
}
|
||||||
|
modelItem.tags = tagString
|
||||||
|
listModel.append(modelItem)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
function getType(suffix) {
|
||||||
|
if (suffix === "ppt" || suffix === "pptx")
|
||||||
|
return "PPT"
|
||||||
|
else if (suffix === "doc" || suffix === "docx")
|
||||||
|
return "WORD"
|
||||||
|
else if (suffix === "pdf")
|
||||||
|
return "PDF"
|
||||||
|
else if (suffix === "txt")
|
||||||
|
return "TXT"
|
||||||
|
else if (suffix === "xls" || suffix === "xlsx")
|
||||||
|
return "EXCEL"
|
||||||
|
else if (suffix === "zip" || suffix === "rar")
|
||||||
|
return "ZIP"
|
||||||
|
else if (suffix === "png" || suffix === "jpg" || suffix === "jpeg"
|
||||||
|
|| suffix === "gif")
|
||||||
|
return "IMAGE"
|
||||||
|
else if (suffix === "mp3" || suffix === "wav")
|
||||||
|
return "AUDIO"
|
||||||
|
else if (suffix === "mp4" || suffix === "avi" || suffix === "rmvb"
|
||||||
|
|| suffix === "rm" || suffix === "wmv" || suffix === "mkv")
|
||||||
|
return "VIDEO"
|
||||||
|
else
|
||||||
|
return "OTHER"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,8 @@ import QtQuick.Window
|
||||||
import QtQuick.Controls
|
import QtQuick.Controls
|
||||||
import QtQuick.Controls.Basic
|
import QtQuick.Controls.Basic
|
||||||
import FluentUI
|
import FluentUI
|
||||||
|
import "qrc:///AicsKnowledgeBase/qml/component"
|
||||||
|
import "qrc:///AicsKnowledgeBase/qml/global"
|
||||||
|
|
||||||
FluArea {
|
FluArea {
|
||||||
property string url: ''
|
property string url: ''
|
||||||
|
@ -17,4 +19,77 @@ FluArea {
|
||||||
Layout.topMargin: 20
|
Layout.topMargin: 20
|
||||||
text: "Local"
|
text: "Local"
|
||||||
}
|
}
|
||||||
|
FileList {
|
||||||
|
anchors.top: title.bottom
|
||||||
|
disableHeader: true
|
||||||
|
width: parent.width
|
||||||
|
dataModel: listModel
|
||||||
|
}
|
||||||
|
ListModel {
|
||||||
|
id: listModel
|
||||||
|
}
|
||||||
|
Component.onCompleted: {
|
||||||
|
var history = UserData.downloadedFiles
|
||||||
|
console.log(history)
|
||||||
|
listModel.clear()
|
||||||
|
for (var i = 0; i < history.length; i++) {
|
||||||
|
Request.get("/knowledge/" + history[i] + "/detailed", response => {
|
||||||
|
var file = JSON.parse(response)
|
||||||
|
|
||||||
|
var modelItem = {
|
||||||
|
"title": file.name,
|
||||||
|
"uuid": file.id,
|
||||||
|
"date"// cut time after 'T'
|
||||||
|
: file.createTime.substring(0, 10),
|
||||||
|
"fuuid": ""
|
||||||
|
}
|
||||||
|
if (file.knowledgeFileAttribute === null) {
|
||||||
|
modelItem.type = "folder"
|
||||||
|
modelItem.isDir = true
|
||||||
|
modelItem.size = 0
|
||||||
|
} else {
|
||||||
|
modelItem.isDir = false
|
||||||
|
modelItem.type = getType(
|
||||||
|
file.knowledgeFileAttribute.suffix)
|
||||||
|
modelItem.size = file.knowledgeFileAttribute.size
|
||||||
|
modelItem.brief = file.knowledgeFileAttribute.brief
|
||||||
|
modelItem.pageView = file.knowledgeFileAttribute.pageView
|
||||||
|
modelItem.stars = 0
|
||||||
|
// merge file.knowledgeFileAttribute.tags array to a string
|
||||||
|
var tagString = ""
|
||||||
|
for (var j = 0; j < file.knowledgeFileAttribute.tags.length; j++) {
|
||||||
|
if (j != 0)
|
||||||
|
tagString = tagString + ","
|
||||||
|
tagString = tagString + file.knowledgeFileAttribute.tags[j].name
|
||||||
|
}
|
||||||
|
modelItem.tags = tagString
|
||||||
|
}
|
||||||
|
listModel.append(modelItem)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function getType(suffix) {
|
||||||
|
if (suffix === "ppt" || suffix === "pptx")
|
||||||
|
return "PPT"
|
||||||
|
else if (suffix === "doc" || suffix === "docx")
|
||||||
|
return "WORD"
|
||||||
|
else if (suffix === "pdf")
|
||||||
|
return "PDF"
|
||||||
|
else if (suffix === "txt")
|
||||||
|
return "TXT"
|
||||||
|
else if (suffix === "xls" || suffix === "xlsx")
|
||||||
|
return "EXCEL"
|
||||||
|
else if (suffix === "zip" || suffix === "rar")
|
||||||
|
return "ZIP"
|
||||||
|
else if (suffix === "png" || suffix === "jpg" || suffix === "jpeg"
|
||||||
|
|| suffix === "gif")
|
||||||
|
return "IMAGE"
|
||||||
|
else if (suffix === "mp3" || suffix === "wav")
|
||||||
|
return "AUDIO"
|
||||||
|
else if (suffix === "mp4" || suffix === "avi" || suffix === "rmvb"
|
||||||
|
|| suffix === "rm" || suffix === "wmv" || suffix === "mkv")
|
||||||
|
return "VIDEO"
|
||||||
|
else
|
||||||
|
return "OTHER"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,8 @@ import "qrc:///AicsKnowledgeBase/qml/component"
|
||||||
FluArea {
|
FluArea {
|
||||||
id: searchPage
|
id: searchPage
|
||||||
property string url: ''
|
property string url: ''
|
||||||
|
property var tags: []
|
||||||
|
property ListModel listModel: ListModel {}
|
||||||
backgroundColor: "#f9f9f9"
|
backgroundColor: "#f9f9f9"
|
||||||
Layout.fillHeight: true
|
Layout.fillHeight: true
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
|
@ -30,52 +32,102 @@ FluArea {
|
||||||
width: parent.width
|
width: parent.width
|
||||||
RowLayout {
|
RowLayout {
|
||||||
width: parent.width
|
width: parent.width
|
||||||
|
|
||||||
// FluDropDownButton{
|
|
||||||
// id:select_model
|
|
||||||
// Layout.alignment: Qt.AlignLeft
|
|
||||||
// text:"标题"
|
|
||||||
// items:[
|
|
||||||
// FluMenuItem{
|
|
||||||
// text:"标题"
|
|
||||||
// onClicked: {
|
|
||||||
// select_model.text = text
|
|
||||||
// }
|
|
||||||
// },
|
|
||||||
// FluMenuItem{
|
|
||||||
// text:"内容"
|
|
||||||
// onClicked: {
|
|
||||||
// select_model.text = text
|
|
||||||
// }
|
|
||||||
// },
|
|
||||||
// FluMenuItem{
|
|
||||||
// text:"标题及内容"
|
|
||||||
// onClicked: {
|
|
||||||
// select_model.text = text
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// ]
|
|
||||||
// }
|
|
||||||
FluTextBox {
|
FluTextBox {
|
||||||
placeholderText: "对标题进行搜索……"
|
placeholderText: "对标题进行搜索……"
|
||||||
|
id: search_text
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
}
|
}
|
||||||
FluIconButton {
|
FluIconButton {
|
||||||
Layout.alignment: Qt.AlignRight
|
Layout.alignment: Qt.AlignRight
|
||||||
iconSource: FluentIcons.Search
|
iconSource: FluentIcons.Search
|
||||||
onClicked: {
|
onClicked: {
|
||||||
var allTags = inputTags.getAllTags(tags.tagList)
|
listModel.clear()
|
||||||
var allTagId = []
|
var allTags = tags.tagMap
|
||||||
console.log(allTags)
|
var selectTagName = []
|
||||||
|
var selectTagId = []
|
||||||
for (var i = 0; i < allTags.length; i++) {
|
for (var i = 0; i < tags.tagList.count; i++) {
|
||||||
var url = "?name="
|
selectTagName.push(tags.tagList.get(i).tag)
|
||||||
url = url + allTags[i]
|
console.log(selectTagName[selectTagName.length - 1])
|
||||||
console.log(url)
|
|
||||||
Request.get(url, function (result, data) {
|
|
||||||
allTagId.push()
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
for (i = 0; i < selectTagName.length; i++) {
|
||||||
|
for (var j = 0; j < allTags.length; j++) {
|
||||||
|
if (selectTagName[i] === allTags[j][1]) {
|
||||||
|
selectTagId.push(allTags[j][0])
|
||||||
|
console.log(allTags[j][0])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var params = {
|
||||||
|
"text": search_text.text,
|
||||||
|
"applyToBriefAndContent": searchTitleAndContent.checked,
|
||||||
|
"tags": selectTagId
|
||||||
|
}
|
||||||
|
var url = "/search/knowledge?"
|
||||||
|
// encode params to get url
|
||||||
|
url += "text=" + params.text
|
||||||
|
url += "&applyToBriefAndContent=" + params.applyToBriefAndContent
|
||||||
|
url += "&tags="
|
||||||
|
for (i = 0; i < params.tags.length; i++) {
|
||||||
|
url += "&tags=" + params.tags[i]
|
||||||
|
}
|
||||||
|
var tagString = ""
|
||||||
|
// merge all tag to a string split by ','
|
||||||
|
for (i = 0; i < selectTagName.length; i++) {
|
||||||
|
if (i !== 0) {
|
||||||
|
tagString += ","
|
||||||
|
}
|
||||||
|
tagString += selectTagName[i]
|
||||||
|
}
|
||||||
|
var sName = ""
|
||||||
|
var sBrief = ""
|
||||||
|
console.log(url)
|
||||||
|
Request.getSearch(url, response => {
|
||||||
|
var dataArray = JSON.parse(response)
|
||||||
|
for (var i = 0; i < dataArray.length; i++) {
|
||||||
|
var data = dataArray[i]
|
||||||
|
if (data.highlightFields.name !== null
|
||||||
|
&& data.highlightFields.name !== undefined
|
||||||
|
&& data.highlightFields.name.length > 0) {
|
||||||
|
for (i = 0; i
|
||||||
|
< data.highlightFields.name.length; i++) {
|
||||||
|
if (i !== 0) {
|
||||||
|
sName += "..."
|
||||||
|
}
|
||||||
|
sName += data.highlightFields.name[i]
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
sName = data.content.name
|
||||||
|
}
|
||||||
|
if (data.highlightFields.brief !== null
|
||||||
|
&& data.highlightFields.brief !== undefined
|
||||||
|
&& data.highlightFields.brief.length > 0) {
|
||||||
|
for (i = 0; i
|
||||||
|
< data.highlightFields.brief.length; i++) {
|
||||||
|
if (i !== 0) {
|
||||||
|
sBrief += "..."
|
||||||
|
}
|
||||||
|
sBrief += data.highlightFields.brief[i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (data.highlightFields.content !== null
|
||||||
|
&& data.highlightFields.content !== undefined
|
||||||
|
&& data.highlightFields.content.length > 0) {
|
||||||
|
for (i = 0; i
|
||||||
|
< data.highlightFields.content.length; i++) {
|
||||||
|
if (i !== 0) {
|
||||||
|
sBrief += "..."
|
||||||
|
}
|
||||||
|
sBrief += data.highlightFields.content[i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (sBrief.length === 0) {
|
||||||
|
sBrief = data.content.brief
|
||||||
|
}
|
||||||
|
getKnowledgeDetail(
|
||||||
|
data.content.uuid, sName,
|
||||||
|
sBrief, tagString)
|
||||||
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -165,56 +217,28 @@ FluArea {
|
||||||
|
|
||||||
FileList {
|
FileList {
|
||||||
disableHeader: true
|
disableHeader: true
|
||||||
dataModel: ListModel {
|
dataModel: listModel
|
||||||
ListElement {
|
|
||||||
uuid: "0"
|
|
||||||
title: "File 1"
|
|
||||||
isDir: true
|
|
||||||
brief: "This is a test file"
|
|
||||||
type: "FOLDER"
|
|
||||||
}
|
|
||||||
ListElement {
|
|
||||||
uuid: "2"
|
|
||||||
title: "File 2"
|
|
||||||
isDir: false
|
|
||||||
brief: "This is a test file"
|
|
||||||
size: 500
|
|
||||||
type: "WORD"
|
|
||||||
date: "2020-09-09"
|
|
||||||
pageView: 100
|
|
||||||
stars: 10
|
|
||||||
}
|
|
||||||
ListElement {
|
|
||||||
uuid: "3"
|
|
||||||
title: "File 3"
|
|
||||||
isDir: false
|
|
||||||
brief: "This is a test file"
|
|
||||||
type: "PPT"
|
|
||||||
date: "2020-09-09"
|
|
||||||
pageView: 100
|
|
||||||
size: 10200000022
|
|
||||||
stars: 10
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
function getKnowledgeDetail(uuid, title, brief, tags) {
|
function getKnowledgeDetail(uuid, title, brief, tags) {
|
||||||
var raw = Request.getAwait("/knowledget/" + uuid)
|
Request.get("/knowledge/" + uuid, raw => {
|
||||||
var data = JSON.parse(raw)
|
var data = JSON.parse(raw)
|
||||||
var item = {
|
var item = {
|
||||||
"uuid": uuid,
|
"uuid": uuid,
|
||||||
"title": title,
|
"title": title,
|
||||||
"brief": brief,
|
"brief": brief,
|
||||||
"isDir": false,
|
"isDir": false,
|
||||||
"date": data.createTime,
|
"date": data.createTime.substring(0, 10),
|
||||||
"fuuid": data.parent.id,
|
"fuuid": "data.parent.id",
|
||||||
"pageView": data.knowledgeFileAttribute.pageView,
|
"pageView": data.knowledgeFileAttribute.pageView,
|
||||||
"stars": data.knowledgeFileAttribute.stars,
|
"stars": data.knowledgeFileAttribute.stars,
|
||||||
"size": data.knowledgeFileAttribute.size,
|
"size": data.knowledgeFileAttribute.size,
|
||||||
"type": getType(data.knowledgeFileAttribute.suffix),
|
"type": getType(data.knowledgeFileAttribute.suffix),
|
||||||
"tags": tags
|
"tags": tags
|
||||||
}
|
}
|
||||||
|
listModel.append(item)
|
||||||
|
})
|
||||||
}
|
}
|
||||||
function getType(suffix) {
|
function getType(suffix) {
|
||||||
if (suffix === "ppt" || suffix === "pptx")
|
if (suffix === "ppt" || suffix === "pptx")
|
||||||
|
|
Loading…
Reference in New Issue