| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- import type { Query as PiniaOrmQuery } from 'pinia-orm'
- import type { ApiFilter } from '~/types/data'
- import ApiResource from '~/models/ApiResource'
- import type { Ref } from "vue";
- export default class EqualFilter implements ApiFilter {
- field: string
- filterValue: string | number | null | Ref<string | number | null>
- reactiveFilter: boolean
- /**
- * @param field
- * @param value
- * @param reactiveFilter Est-ce qu'on doit conserver la réactivité du filtre ? Concrètement, dans le cas d'une
- * recherche textuelle, si le filtre est réactif, le résultat de la query Pinia-ORM sera
- * filtré à chaque fois que le filtre est modifié (même sans refresh ou nouvel appel à
- * fetchCollection). Si reactiveFilter est false (comportement par défaut), le résultat
- * de la query ne sera mis à jour qu'en cas de nouvel appel à fetchCollection (ou à refresh()).
- */
- constructor(
- field: string,
- value: string | number | null | Ref<string | number | null>,
- reactiveFilter: boolean = false,
- ) {
- this.field = field
- this.filterValue = value
- this.reactiveFilter = reactiveFilter
- }
- protected filterValueToRef(): Ref<string | number | null> {
- if (isRef(this.filterValue)) {
- if (this.reactiveFilter) {
- return this.filterValue
- } else {
- return ref(this.filterValue.value)
- }
- } else {
- return ref(this.filterValue)
- }
- }
- public applyToPiniaOrmQuery(
- query: PiniaOrmQuery<ApiResource>,
- ): PiniaOrmQuery<ApiResource> {
- const filterValue = this.filterValueToRef()
- if (filterValue.value === null) {
- return query
- }
- return query.where(this.field, filterValue.value)
- }
- public getApiQueryPart(): string {
- const filterValue = this.filterValueToRef()
- if (filterValue.value === null) {
- return ''
- }
- return `${this.field}=${filterValue.value}`
- }
- }
|