Merge pull request #1024 from eikek/enhance-search-mode

Enhance search mode to search in all items
This commit is contained in:
mergify[bot] 2021-08-21 13:56:43 +00:00 committed by GitHub
commit 45f6357f49
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 19 additions and 3 deletions

View File

@ -220,6 +220,7 @@ object OSimpleSearch {
settings.searchMode match {
case SearchMode.Trashed => q.withFix(_.andQuery(ItemQuery.Expr.Trashed))
case SearchMode.Normal => q.withFix(_.andQuery(ItemQuery.Expr.ValidItemStates))
case SearchMode.All => q.withFix(_.andQuery(ItemQuery.Expr.ValidItemsOrTrashed))
}
fulltextQuery match {
case Some(ftq) if settings.useFTS =>
@ -282,6 +283,7 @@ object OSimpleSearch {
settings.searchMode match {
case SearchMode.Trashed => q.withFix(_.andQuery(ItemQuery.Expr.Trashed))
case SearchMode.Normal => q.withFix(_.andQuery(ItemQuery.Expr.ValidItemStates))
case SearchMode.All => q.withFix(_.andQuery(ItemQuery.Expr.ValidItemsOrTrashed))
}
fulltextQuery match {
case Some(ftq) if settings.useFTS =>

View File

@ -52,6 +52,9 @@ object ItemState {
val invalidStates: NonEmptyList[ItemState] =
NonEmptyList.of(Premature, Processing)
val validStatesAndDeleted: NonEmptyList[ItemState] =
validStates.append(deleted)
def unsafe(str: String): ItemState =
fromString(str).fold(sys.error, identity)

View File

@ -22,11 +22,13 @@ object SearchMode {
final case object Normal extends SearchMode
final case object Trashed extends SearchMode
final case object All extends SearchMode
def fromString(str: String): Either[String, SearchMode] =
str.toLowerCase match {
case "normal" => Right(Normal)
case "trashed" => Right(Trashed)
case "all" => Right(All)
case _ => Left(s"Invalid search mode: $str")
}

View File

@ -125,6 +125,7 @@ object ItemQuery {
final case object ValidItemStates extends Expr
final case object Trashed extends Expr
final case object ValidItemsOrTrashed extends Expr
// things that can be expressed with terms above
sealed trait MacroExpr extends Expr {

View File

@ -79,6 +79,8 @@ object ExprUtil {
expr
case Trashed =>
expr
case ValidItemsOrTrashed =>
expr
}
private def spliceAnd(nodes: Nel[Expr]): Nel[Expr] =

View File

@ -4228,6 +4228,7 @@ components:
enum:
- normal
- trashed
- all
default: normal
description: |
Specify whether the search query should apply to
@ -5990,10 +5991,12 @@ components:
searchMode:
name: searchMode
in: query
description: Whether to search in soft-deleted items only.
schema:
type: string
format: searchmode
description: |
Specify whether the search query should apply to soft-deleted
items or not.
name:
name: name
in: path

View File

@ -129,6 +129,9 @@ object ItemQueryGenerator {
case Expr.Trashed =>
tables.item.state === ItemState.Deleted
case Expr.ValidItemsOrTrashed =>
tables.item.state.in(ItemState.validStatesAndDeleted)
case Expr.TagIdsMatch(op, tags) =>
val ids = tags.toList.flatMap(s => Ident.fromString(s).toOption)
Nel