mirror of
https://github.com/TheAnachronism/docspell.git
synced 2025-04-05 02:49:32 +00:00
Get basic search summary
This commit is contained in:
parent
56d6d2e2ac
commit
4ca6dfccae
@ -66,8 +66,8 @@ trait OCollective[F[_]] {
|
|||||||
|
|
||||||
object OCollective {
|
object OCollective {
|
||||||
|
|
||||||
type TagCount = QCollective.TagCount
|
type TagCount = docspell.store.queries.TagCount
|
||||||
val TagCount = QCollective.TagCount
|
val TagCount = docspell.store.queries.TagCount
|
||||||
|
|
||||||
type InsightData = QCollective.InsightData
|
type InsightData = QCollective.InsightData
|
||||||
val insightData = QCollective.InsightData
|
val insightData = QCollective.InsightData
|
||||||
|
@ -24,6 +24,8 @@ trait OItemSearch[F[_]] {
|
|||||||
maxNoteLen: Int
|
maxNoteLen: Int
|
||||||
)(q: Query, batch: Batch): F[Vector[ListItemWithTags]]
|
)(q: Query, batch: Batch): F[Vector[ListItemWithTags]]
|
||||||
|
|
||||||
|
def findItemsSummary(q: Query): F[SearchSummary]
|
||||||
|
|
||||||
def findAttachment(id: Ident, collective: Ident): F[Option[AttachmentData[F]]]
|
def findAttachment(id: Ident, collective: Ident): F[Option[AttachmentData[F]]]
|
||||||
|
|
||||||
def findAttachmentSource(
|
def findAttachmentSource(
|
||||||
@ -53,6 +55,9 @@ trait OItemSearch[F[_]] {
|
|||||||
|
|
||||||
object OItemSearch {
|
object OItemSearch {
|
||||||
|
|
||||||
|
type SearchSummary = queries.SearchSummary
|
||||||
|
val SearchSummary = queries.SearchSummary
|
||||||
|
|
||||||
type CustomValue = queries.CustomValue
|
type CustomValue = queries.CustomValue
|
||||||
val CustomValue = queries.CustomValue
|
val CustomValue = queries.CustomValue
|
||||||
|
|
||||||
@ -139,6 +144,12 @@ object OItemSearch {
|
|||||||
.toVector
|
.toVector
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def findItemsSummary(q: Query): F[SearchSummary] =
|
||||||
|
for {
|
||||||
|
tags <- store.transact(QItem.searchTagSummary(q))
|
||||||
|
count <- store.transact(QItem.searchCountSummary(q))
|
||||||
|
} yield SearchSummary(count, tags)
|
||||||
|
|
||||||
def findAttachment(id: Ident, collective: Ident): F[Option[AttachmentData[F]]] =
|
def findAttachment(id: Ident, collective: Ident): F[Option[AttachmentData[F]]] =
|
||||||
store
|
store
|
||||||
.transact(RAttachment.findByIdAndCollective(id, collective))
|
.transact(RAttachment.findByIdAndCollective(id, collective))
|
||||||
|
@ -33,8 +33,6 @@ object QCollective {
|
|||||||
} yield Names(orgs.map(_.name), pers.map(_.name), equp.map(_.name)))
|
} yield Names(orgs.map(_.name), pers.map(_.name), equp.map(_.name)))
|
||||||
.getOrElse(Names.empty)
|
.getOrElse(Names.empty)
|
||||||
|
|
||||||
case class TagCount(tag: RTag, count: Int)
|
|
||||||
|
|
||||||
case class InsightData(
|
case class InsightData(
|
||||||
incoming: Int,
|
incoming: Int,
|
||||||
outgoing: Int,
|
outgoing: Int,
|
||||||
|
@ -234,6 +234,30 @@ object QItem {
|
|||||||
sql.query[ListItem].stream
|
sql.query[ListItem].stream
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def searchTagSummary(q: Query): ConnectionIO[List[TagCount]] = {
|
||||||
|
val tagFrom =
|
||||||
|
from(ti)
|
||||||
|
.innerJoin(tag, tag.tid === ti.tagId)
|
||||||
|
.innerJoin(i, i.id === ti.itemId)
|
||||||
|
|
||||||
|
findItemsBase(q, 0)
|
||||||
|
.withSelect(select(tag.all).append(count(i.id).as("num")))
|
||||||
|
.changeFrom(_.prepend(tagFrom))
|
||||||
|
.changeWhere(c => c && queryCondition(q))
|
||||||
|
.groupBy(tag.tid)
|
||||||
|
.build
|
||||||
|
.query[TagCount]
|
||||||
|
.to[List]
|
||||||
|
}
|
||||||
|
|
||||||
|
def searchCountSummary(q: Query): ConnectionIO[Int] =
|
||||||
|
findItemsBase(q, 0)
|
||||||
|
.withSelect(Nel.of(count(i.id).as("num")))
|
||||||
|
.changeWhere(c => c && queryCondition(q))
|
||||||
|
.build
|
||||||
|
.query[Int]
|
||||||
|
.unique
|
||||||
|
|
||||||
def findSelectedItems(
|
def findSelectedItems(
|
||||||
q: Query,
|
q: Query,
|
||||||
maxNoteLen: Int,
|
maxNoteLen: Int,
|
||||||
|
@ -0,0 +1,3 @@
|
|||||||
|
package docspell.store.queries
|
||||||
|
|
||||||
|
case class SearchSummary(count: Int, tags: List[TagCount])
|
@ -0,0 +1,5 @@
|
|||||||
|
package docspell.store.queries
|
||||||
|
|
||||||
|
import docspell.store.records.RTag
|
||||||
|
|
||||||
|
case class TagCount(tag: RTag, count: Int)
|
Loading…
x
Reference in New Issue
Block a user