1
0
Fork 0
peertube/client/src/app/shared/shared-search/advanced-search.model.ts

169 lines
4.5 KiB
TypeScript
Raw Normal View History

import { BooleanBothQuery, SearchTargetType } from '@shared/models'
2018-07-20 16:31:49 +00:00
export class AdvancedSearch {
startDate: string // ISO 8601
endDate: string // ISO 8601
originallyPublishedStartDate: string // ISO 8601
originallyPublishedEndDate: string // ISO 8601
nsfw: BooleanBothQuery
2018-07-20 16:31:49 +00:00
categoryOneOf: string
licenceOneOf: string
languageOneOf: string
2020-08-11 07:22:42 +00:00
tagsOneOf: string[]
tagsAllOf: string[]
2018-07-20 16:31:49 +00:00
durationMin: number // seconds
durationMax: number // seconds
2018-07-24 08:13:54 +00:00
sort: string
2020-05-29 14:16:24 +00:00
searchTarget: SearchTargetType
// Filters we don't want to count, because they are mandatory
private silentFilters = new Set([ 'sort', 'searchTarget' ])
2018-07-20 16:31:49 +00:00
constructor (options?: {
startDate?: string
endDate?: string
originallyPublishedStartDate?: string
originallyPublishedEndDate?: string
nsfw?: BooleanBothQuery
2018-07-20 16:31:49 +00:00
categoryOneOf?: string
licenceOneOf?: string
languageOneOf?: string
2020-08-11 07:22:42 +00:00
tagsOneOf?: any
tagsAllOf?: any
2018-07-20 16:31:49 +00:00
durationMin?: string
durationMax?: string
2018-07-24 08:13:54 +00:00
sort?: string
2020-05-29 14:16:24 +00:00
searchTarget?: SearchTargetType
2018-07-20 16:31:49 +00:00
}) {
if (!options) return
this.startDate = options.startDate || undefined
this.endDate = options.endDate || undefined
this.originallyPublishedStartDate = options.originallyPublishedStartDate || undefined
this.originallyPublishedEndDate = options.originallyPublishedEndDate || undefined
this.nsfw = options.nsfw || undefined
this.categoryOneOf = options.categoryOneOf || undefined
this.licenceOneOf = options.licenceOneOf || undefined
this.languageOneOf = options.languageOneOf || undefined
2020-08-11 07:22:42 +00:00
this.tagsOneOf = this.intoArray(options.tagsOneOf)
this.tagsAllOf = this.intoArray(options.tagsAllOf)
2018-07-20 16:31:49 +00:00
this.durationMin = parseInt(options.durationMin, 10)
this.durationMax = parseInt(options.durationMax, 10)
2020-05-29 14:16:24 +00:00
this.searchTarget = options.searchTarget || undefined
2018-07-20 16:31:49 +00:00
if (isNaN(this.durationMin)) this.durationMin = undefined
if (isNaN(this.durationMax)) this.durationMax = undefined
2018-07-24 08:13:54 +00:00
this.sort = options.sort || '-match'
2018-07-20 16:31:49 +00:00
}
containsValues () {
2018-10-18 12:35:31 +00:00
const obj = this.toUrlObject()
2018-07-20 16:31:49 +00:00
for (const k of Object.keys(obj)) {
2020-05-29 14:16:24 +00:00
if (this.silentFilters.has(k)) continue
2018-07-24 08:13:54 +00:00
2020-08-11 07:22:42 +00:00
if (this.isValidValue(obj[k])) return true
2018-07-20 16:31:49 +00:00
}
return false
}
reset () {
this.startDate = undefined
this.endDate = undefined
this.originallyPublishedStartDate = undefined
this.originallyPublishedEndDate = undefined
2018-07-20 16:31:49 +00:00
this.nsfw = undefined
this.categoryOneOf = undefined
this.licenceOneOf = undefined
this.languageOneOf = undefined
this.tagsOneOf = undefined
this.tagsAllOf = undefined
this.durationMin = undefined
this.durationMax = undefined
2018-07-24 08:13:54 +00:00
this.sort = '-match'
2018-07-20 16:31:49 +00:00
}
toUrlObject () {
return {
startDate: this.startDate,
endDate: this.endDate,
originallyPublishedStartDate: this.originallyPublishedStartDate,
originallyPublishedEndDate: this.originallyPublishedEndDate,
2018-07-20 16:31:49 +00:00
nsfw: this.nsfw,
categoryOneOf: this.categoryOneOf,
licenceOneOf: this.licenceOneOf,
languageOneOf: this.languageOneOf,
tagsOneOf: this.tagsOneOf,
tagsAllOf: this.tagsAllOf,
durationMin: this.durationMin,
2018-07-24 08:13:54 +00:00
durationMax: this.durationMax,
2020-05-29 14:16:24 +00:00
sort: this.sort,
searchTarget: this.searchTarget
2018-07-20 16:31:49 +00:00
}
}
toAPIObject () {
return {
startDate: this.startDate,
endDate: this.endDate,
originallyPublishedStartDate: this.originallyPublishedStartDate,
originallyPublishedEndDate: this.originallyPublishedEndDate,
2018-07-20 16:31:49 +00:00
nsfw: this.nsfw,
categoryOneOf: this.intoArray(this.categoryOneOf),
licenceOneOf: this.intoArray(this.licenceOneOf),
languageOneOf: this.intoArray(this.languageOneOf),
2020-08-11 07:22:42 +00:00
tagsOneOf: this.tagsOneOf,
tagsAllOf: this.tagsAllOf,
2018-07-20 16:31:49 +00:00
durationMin: this.durationMin,
2018-07-24 08:13:54 +00:00
durationMax: this.durationMax,
2020-05-29 14:16:24 +00:00
sort: this.sort,
searchTarget: this.searchTarget
2018-07-20 16:31:49 +00:00
}
}
size () {
let acc = 0
2018-10-18 12:35:31 +00:00
const obj = this.toUrlObject()
for (const k of Object.keys(obj)) {
2020-05-29 14:16:24 +00:00
if (this.silentFilters.has(k)) continue
2020-08-11 07:22:42 +00:00
if (this.isValidValue(obj[k])) acc++
}
return acc
}
2020-08-11 07:22:42 +00:00
private isValidValue (val: any) {
if (val === undefined) return false
if (val === '') return false
if (Array.isArray(val) && val.length === 0) return false
return true
}
private intoArray (value: any) {
if (!value) return undefined
if (Array.isArray(value)) return value
if (typeof value === 'string') return value.split(',')
return [ value ]
}
2018-07-20 16:31:49 +00:00
}