paperless-ngx/src-ui/src/app/services/rest/saved-view.service.ts

94 lines
2.5 KiB
TypeScript
Raw Normal View History

import { HttpClient } from '@angular/common/http'
import { Injectable } from '@angular/core'
import { combineLatest, Observable } from 'rxjs'
import { tap } from 'rxjs/operators'
2023-12-19 22:36:35 -08:00
import { SavedView } from 'src/app/data/saved-view'
import { AbstractPaperlessService } from './abstract-paperless-service'
import { SettingsService } from '../settings.service'
2023-12-19 22:36:35 -08:00
import { SETTINGS_KEYS } from 'src/app/data/ui-settings'
@Injectable({
providedIn: 'root',
})
2023-12-19 22:36:35 -08:00
export class SavedViewService extends AbstractPaperlessService<SavedView> {
public loading: boolean = true
private savedViews: SavedView[] = []
constructor(
protected http: HttpClient,
private settingsService: SettingsService
) {
super(http, 'saved_views')
}
public initialize() {
this.reload()
}
private reload() {
this.listAll().subscribe({
next: (r) => {
this.savedViews = r.results
this.loading = false
this.settingsService.dashboardIsEmpty = this.dashboardViews.length === 0
},
error: () => {
this.loading = false
this.settingsService.dashboardIsEmpty = true
},
})
}
get allViews() {
return this.savedViews
}
2023-12-19 22:36:35 -08:00
get sidebarViews(): SavedView[] {
const sidebarViews = this.savedViews.filter((v) => v.show_in_sidebar)
const sorted: number[] = this.settingsService.get(
SETTINGS_KEYS.SIDEBAR_VIEWS_SORT_ORDER
)
return sorted?.length > 0
? sorted
.map((id) => sidebarViews.find((v) => v.id === id))
.concat(sidebarViews.filter((v) => !sorted.includes(v.id)))
.filter((v) => v)
: [...sidebarViews]
}
2023-12-19 22:36:35 -08:00
get dashboardViews(): SavedView[] {
const dashboardViews = this.savedViews.filter((v) => v.show_on_dashboard)
const sorted: number[] = this.settingsService.get(
SETTINGS_KEYS.DASHBOARD_VIEWS_SORT_ORDER
)
return sorted?.length > 0
? sorted
.map((id) => dashboardViews.find((v) => v.id === id))
.concat(dashboardViews.filter((v) => !sorted.includes(v.id)))
.filter((v) => v)
: [...dashboardViews]
}
2023-12-19 22:36:35 -08:00
create(o: SavedView) {
return super.create(o).pipe(tap(() => this.reload()))
}
2023-12-19 22:36:35 -08:00
update(o: SavedView) {
return super.update(o).pipe(tap(() => this.reload()))
}
2023-12-19 22:36:35 -08:00
patchMany(objects: SavedView[]): Observable<SavedView[]> {
return combineLatest(objects.map((o) => super.patch(o))).pipe(
2020-12-15 02:35:04 +01:00
tap(() => this.reload())
)
}
2023-12-19 22:36:35 -08:00
delete(o: SavedView) {
return super.delete(o).pipe(tap(() => this.reload()))
}
}