Impl post_search_config.py's create_around_query()
This commit is contained in:
parent
6a0d5741c3
commit
719f6dc741
1 changed files with 14 additions and 2 deletions
|
@ -220,8 +220,20 @@ class PostSearchConfig(BaseSearchConfig):
|
||||||
if token.name == "pool" and isinstance(token.criterion, criteria.PlainCriterion):
|
if token.name == "pool" and isinstance(token.criterion, criteria.PlainCriterion):
|
||||||
self.pool_id = token.criterion.value
|
self.pool_id = token.criterion.value
|
||||||
|
|
||||||
def create_around_query(self) -> SaQuery:
|
def create_around_query(self, filter_query: SaQuery, entity_id: int) -> SaQuery:
|
||||||
return db.session.query(model.Post).options(sa.orm.lazyload("*"))
|
prev_filter_query = (
|
||||||
|
filter_query.filter(self.config.id_column > entity_id)
|
||||||
|
.order_by(None)
|
||||||
|
.order_by(sa.func.abs(self.config.id_column - entity_id).asc())
|
||||||
|
.limit(1)
|
||||||
|
)
|
||||||
|
next_filter_query = (
|
||||||
|
filter_query.filter(self.config.id_column < entity_id)
|
||||||
|
.order_by(None)
|
||||||
|
.order_by(sa.func.abs(self.config.id_column - entity_id).asc())
|
||||||
|
.limit(1)
|
||||||
|
)
|
||||||
|
return prev_filter_query, next_filter_query
|
||||||
|
|
||||||
def create_around_filter_queries(self, filter_query: SaQuery, entity_id: int) -> Tuple[SaQuery, SaQuery]:
|
def create_around_filter_queries(self, filter_query: SaQuery, entity_id: int) -> Tuple[SaQuery, SaQuery]:
|
||||||
if self.pool_id is not None:
|
if self.pool_id is not None:
|
||||||
|
|
Loading…
Reference in a new issue