This commit is contained in:
Liang Ding 2022-12-09 12:08:07 +08:00
parent dd617d6089
commit 167b0fda6f
No known key found for this signature in database
GPG key ID: 136F30F901A2231D
9 changed files with 37 additions and 7 deletions

View file

@ -1,4 +1,6 @@
{
"sortByRankDesc": "Relevance DESC",
"sortByRankAsc": "Relevance ASC",
"saveCriterion": "Save named criterion",
"useCriterion": "Use named criterion",
"group": "Group",

View file

@ -1,4 +1,6 @@
{
"sortByRankDesc": "Relevancia DESC",
"sortByRankAsc": "Relevancia ASC",
"saveCriterion": "Guardar criterio nombrado",
"useCriterion": "Usar criterio con nombre",
"grupo": "Grupo",

View file

@ -1,4 +1,6 @@
{
"sortByRankDesc": "DESC de pertinence",
"sortByRankAsc": "ASC de pertinence",
"saveCriterion": "Enregistrer le critère nommé",
"useCriterion": "Utiliser le critère nommé",
"groupe": "Groupe",

View file

@ -1,4 +1,6 @@
{
"sortByRankDesc": "按相關度降序",
"sortByRankAsc": "按相關度升序",
"saveCriterion": "保存命名查詢",
"useCriterion": "使用命名查詢",
"group": "分組",

View file

@ -1,4 +1,6 @@
{
"sortByRankDesc": "按相关度降序",
"sortByRankAsc": "按相关度升序",
"saveCriterion": "保存命名查询",
"useCriterion": "使用命名查询",
"group": "分组",

View file

@ -597,6 +597,20 @@ const addConfigMoreMenu = async (config: ISearchOption, edit: Protyle, element:
config.sort = 4;
inputEvent(element, config, undefined, edit);
}
}, {
label: window.siyuan.languages.sortByRankAsc,
current: config.sort === 6,
click() {
config.sort = 6;
inputEvent(element, config, undefined, edit);
}
}, {
label: window.siyuan.languages.sortByRankDesc,
current: config.sort === 7,
click() {
config.sort = 7;
inputEvent(element, config, undefined, edit);
}
}];
if (config.group === 1) {
sortMenu.push({

View file

@ -53,7 +53,7 @@ interface Window {
interface ISearchOption {
name?: string
sort: number, // 0按块类型默认1按创建时间升序2按创建时间降序3按更新时间升序4按更新时间降序5按内容顺序仅在按文档分组时
sort: number, // 0按块类型默认1按创建时间升序2按创建时间降序3按更新时间升序4按更新时间降序5按内容顺序仅在按文档分组时6按相关度升序7按相关度降序
group: number, // 0不分组1按文档分组
layout: number // 0上下1左右
hasReplace: boolean,

View file

@ -219,12 +219,12 @@ func fullTextSearchBlock(c *gin.Context) {
}
}
methodArg := arg["method"]
var method int // 0文本1查询语法2SQL3正则表达式
var method int // 0关键字1查询语法2SQL3正则表达式
if nil != methodArg {
method = int(methodArg.(float64))
}
orderByArg := arg["orderBy"]
var orderBy int // 0按块类型默认1按创建时间升序2按创建时间降序3按更新时间升序4按更新时间降序5按内容顺序仅在按文档分组时
var orderBy int // 0按块类型默认1按创建时间升序2按创建时间降序3按更新时间升序4按更新时间降序5按内容顺序仅在按文档分组时6按相关度升序7按相关度降序
if nil != orderByArg {
orderBy = int(orderByArg.(float64))
}

View file

@ -314,8 +314,8 @@ func FindReplace(keyword, replacement string, ids []string, method int) (err err
// FullTextSearchBlock 搜索内容块。
//
// method0文本1查询语法2SQL3正则表达式
// orderBy: 0按块类型默认1按创建时间升序2按创建时间降序3按更新时间升序4按更新时间降序5按内容顺序仅在按文档分组时
// method0关键字1查询语法2SQL3正则表达式
// orderBy: 0按块类型默认1按创建时间升序2按创建时间降序3按更新时间升序4按更新时间降序5按内容顺序仅在按文档分组时6按相关度升序7按相关度降序
// groupBy0不分组1按文档分组
func FullTextSearchBlock(query string, boxes, paths []string, types map[string]bool, method, orderBy, groupBy int) (ret []*Block, matchedBlockCount, matchedRootCount int) {
query = strings.TrimSpace(query)
@ -335,7 +335,7 @@ func FullTextSearchBlock(query string, boxes, paths []string, types map[string]b
boxFilter := buildBoxesFilter(boxes)
pathFilter := buildPathsFilter(paths)
blocks, matchedBlockCount, matchedRootCount = fullTextSearchByRegexp(query, boxFilter, pathFilter, typeFilter, orderByClause, beforeLen)
default: // 文本
default: // 关键字
filter := buildTypeFilter(types)
boxFilter := buildBoxesFilter(boxes)
pathFilter := buildPathsFilter(paths)
@ -412,6 +412,8 @@ func FullTextSearchBlock(query string, boxes, paths []string, types map[string]b
sort.Slice(roots, func(i, j int) bool { return roots[i].Updated > roots[j].Updated })
case 5: // 按内容顺序(仅在按文档分组时)
// 都是文档,不需要再次排序
case 6, 7: // 按相关度
// 已在 ORDER BY 中处理
default: // 按块类型(默认)
// 都是文档,不需要再次排序
}
@ -467,6 +469,10 @@ func buildOrderBy(orderBy int) string {
return "ORDER BY updated ASC"
case 4:
return "ORDER BY updated DESC"
case 6:
return "ORDER BY rank DESC" // 默认是按相关度降序,所以按相关度升序要反过来使用 DESC
case 7:
return "ORDER BY rank" // 默认是按相关度降序
default:
return "ORDER BY sort ASC"
}