PeerTube/client/src/app/+search/search-filters.component.ts

254 lines
6.9 KiB
TypeScript

import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'
import { ServerService } from '@app/core'
import { AdvancedSearch } from '@app/shared/shared-search'
import { HTMLServerConfig, VideoConstant } from '@shared/models'
type FormOption = { id: string, label: string }
@Component({
selector: 'my-search-filters',
styleUrls: [ './search-filters.component.scss' ],
templateUrl: './search-filters.component.html'
})
export class SearchFiltersComponent implements OnInit {
@Input() advancedSearch: AdvancedSearch = new AdvancedSearch()
@Output() filtered = new EventEmitter<AdvancedSearch>()
videoCategories: VideoConstant<number>[] = []
videoLicences: VideoConstant<number>[] = []
videoLanguages: VideoConstant<string>[] = []
publishedDateRanges: FormOption[] = []
sorts: FormOption[] = []
durationRanges: FormOption[] = []
publishedDateRange: string
durationRange: string
originallyPublishedStartYear: string
originallyPublishedEndYear: string
private serverConfig: HTMLServerConfig
constructor (
private serverService: ServerService
) {
this.publishedDateRanges = [
{
id: 'today',
label: $localize`Today`
},
{
id: 'last_7days',
label: $localize`Last 7 days`
},
{
id: 'last_30days',
label: $localize`Last 30 days`
},
{
id: 'last_365days',
label: $localize`Last 365 days`
}
]
this.durationRanges = [
{
id: 'short',
label: $localize`Short (< 4 min)`
},
{
id: 'medium',
label: $localize`Medium (4-10 min)`
},
{
id: 'long',
label: $localize`Long (> 10 min)`
}
]
this.sorts = [
{
id: '-match',
label: $localize`Relevance`
},
{
id: '-publishedAt',
label: $localize`Publish date`
},
{
id: '-views',
label: $localize`Views`
}
]
}
ngOnInit () {
this.serverConfig = this.serverService.getHTMLConfig()
this.serverService.getVideoCategories().subscribe(categories => this.videoCategories = categories)
this.serverService.getVideoLicences().subscribe(licences => this.videoLicences = licences)
this.serverService.getVideoLanguages().subscribe(languages => this.videoLanguages = languages)
this.loadFromDurationRange()
this.loadFromPublishedRange()
this.loadOriginallyPublishedAtYears()
}
onDurationOrPublishedUpdated () {
this.updateModelFromDurationRange()
this.updateModelFromPublishedRange()
this.updateModelFromOriginallyPublishedAtYears()
}
formUpdated () {
this.onDurationOrPublishedUpdated()
this.filtered.emit(this.advancedSearch)
}
reset () {
this.advancedSearch.reset()
this.resetOriginalPublicationYears()
this.durationRange = undefined
this.publishedDateRange = undefined
this.onDurationOrPublishedUpdated()
}
resetField (fieldName: keyof AdvancedSearch, value?: any) {
(this.advancedSearch as any)[fieldName] = value
}
resetLocalField (fieldName: keyof SearchFiltersComponent, value?: any) {
this[fieldName] = value
this.onDurationOrPublishedUpdated()
}
resetOriginalPublicationYears () {
this.originallyPublishedStartYear = this.originallyPublishedEndYear = undefined
}
isSearchTargetEnabled () {
return this.serverConfig.search.searchIndex.enabled && this.serverConfig.search.searchIndex.disableLocalSearch !== true
}
private loadOriginallyPublishedAtYears () {
this.originallyPublishedStartYear = this.advancedSearch.originallyPublishedStartDate
? new Date(this.advancedSearch.originallyPublishedStartDate).getFullYear().toString()
: undefined
this.originallyPublishedEndYear = this.advancedSearch.originallyPublishedEndDate
? new Date(this.advancedSearch.originallyPublishedEndDate).getFullYear().toString()
: undefined
}
private loadFromDurationRange () {
if (this.advancedSearch.durationMin || this.advancedSearch.durationMax) {
const fourMinutes = 60 * 4
const tenMinutes = 60 * 10
if (this.advancedSearch.durationMin === fourMinutes && this.advancedSearch.durationMax === tenMinutes) {
this.durationRange = 'medium'
} else if (this.advancedSearch.durationMax === fourMinutes) {
this.durationRange = 'short'
} else if (this.advancedSearch.durationMin === tenMinutes) {
this.durationRange = 'long'
}
}
}
private loadFromPublishedRange () {
if (this.advancedSearch.startDate) {
const date = new Date(this.advancedSearch.startDate)
const now = new Date()
const diff = Math.abs(date.getTime() - now.getTime())
const dayMS = 1000 * 3600 * 24
const numberOfDays = diff / dayMS
if (numberOfDays >= 365) this.publishedDateRange = 'last_365days'
else if (numberOfDays >= 30) this.publishedDateRange = 'last_30days'
else if (numberOfDays >= 7) this.publishedDateRange = 'last_7days'
else if (numberOfDays >= 0) this.publishedDateRange = 'today'
}
}
private updateModelFromOriginallyPublishedAtYears () {
const baseDate = new Date()
baseDate.setHours(0, 0, 0, 0)
baseDate.setMonth(0, 1)
if (this.originallyPublishedStartYear) {
const year = parseInt(this.originallyPublishedStartYear, 10)
const start = new Date(baseDate)
start.setFullYear(year)
this.advancedSearch.originallyPublishedStartDate = start.toISOString()
} else {
this.advancedSearch.originallyPublishedStartDate = undefined
}
if (this.originallyPublishedEndYear) {
const year = parseInt(this.originallyPublishedEndYear, 10)
const end = new Date(baseDate)
end.setFullYear(year)
this.advancedSearch.originallyPublishedEndDate = end.toISOString()
} else {
this.advancedSearch.originallyPublishedEndDate = undefined
}
}
private updateModelFromDurationRange () {
if (!this.durationRange) return
const fourMinutes = 60 * 4
const tenMinutes = 60 * 10
switch (this.durationRange) {
case 'short':
this.advancedSearch.durationMin = undefined
this.advancedSearch.durationMax = fourMinutes
break
case 'medium':
this.advancedSearch.durationMin = fourMinutes
this.advancedSearch.durationMax = tenMinutes
break
case 'long':
this.advancedSearch.durationMin = tenMinutes
this.advancedSearch.durationMax = undefined
break
}
}
private updateModelFromPublishedRange () {
if (!this.publishedDateRange) return
// today
const date = new Date()
date.setHours(0, 0, 0, 0)
switch (this.publishedDateRange) {
case 'last_7days':
date.setDate(date.getDate() - 7)
break
case 'last_30days':
date.setDate(date.getDate() - 30)
break
case 'last_365days':
date.setDate(date.getDate() - 365)
break
}
this.advancedSearch.startDate = date.toISOString()
}
}