mirror of
https://github.com/TheAnachronism/docspell.git
synced 2025-04-05 10:59:33 +00:00
Extract find-item query condition
This commit is contained in:
parent
2dff686fa0
commit
f1c4b4adb0
@ -170,17 +170,17 @@ object Select {
|
||||
|
||||
}
|
||||
|
||||
case class WithCte(cte: CteBind, ctes: Vector[CteBind], query: Select) extends Select {
|
||||
case class WithCte(cte: CteBind, ctes: Vector[CteBind], q: Select) extends Select {
|
||||
def appendSelect(e: SelectExpr): WithCte =
|
||||
copy(query = query.appendSelect(e))
|
||||
copy(q = q.appendSelect(e))
|
||||
|
||||
def changeFrom(f: FromExpr => FromExpr): WithCte =
|
||||
copy(query = query.changeFrom(f))
|
||||
copy(q = q.changeFrom(f))
|
||||
|
||||
def changeWhere(f: Condition => Condition): WithCte =
|
||||
copy(query = query.changeWhere(f))
|
||||
copy(q = q.changeWhere(f))
|
||||
|
||||
def orderBy(ob: OrderBy, obs: OrderBy*): WithCte =
|
||||
copy(query = query.orderBy(ob, obs: _*))
|
||||
copy(q = q.orderBy(ob, obs: _*))
|
||||
}
|
||||
}
|
||||
|
@ -164,7 +164,7 @@ object QItem {
|
||||
i.cid === q.account.collective,
|
||||
GroupBy(a.itemId)
|
||||
),
|
||||
Attachs.aliasName, //alias, todo improve dsl
|
||||
Attachs.aliasName,
|
||||
Attachs.itemId === i.id
|
||||
)
|
||||
.leftJoin(pers0, pers0.pid === i.corrPerson && pers0.cid === coll)
|
||||
@ -189,14 +189,8 @@ object QItem {
|
||||
}
|
||||
}
|
||||
|
||||
def findItems(
|
||||
q: Query,
|
||||
maxNoteLen: Int,
|
||||
batch: Batch
|
||||
): Stream[ConnectionIO, ListItem] = {
|
||||
val cond: Condition => Condition =
|
||||
c =>
|
||||
c &&?
|
||||
def queryCondition(q: Query): Condition =
|
||||
Condition.unit &&?
|
||||
q.direction.map(d => i.incoming === d) &&?
|
||||
q.name.map(n => i.name.like(QueryWildcard.lower(n))) &&?
|
||||
q.allNames
|
||||
@ -227,8 +221,13 @@ object QItem {
|
||||
.itemsWithEitherTagOrCategory(q.tagsExclude, q.tagCategoryExcl)
|
||||
.map(subsel => i.id.notIn(subsel))
|
||||
|
||||
def findItems(
|
||||
q: Query,
|
||||
maxNoteLen: Int,
|
||||
batch: Batch
|
||||
): Stream[ConnectionIO, ListItem] = {
|
||||
val sql = findItemsBase(q, maxNoteLen)
|
||||
.changeWhere(cond)
|
||||
.changeWhere(c => c && queryCondition(q))
|
||||
.limit(batch)
|
||||
.build
|
||||
logger.trace(s"List $batch items: $sql")
|
||||
|
Loading…
x
Reference in New Issue
Block a user