thingsboard/ui-ngx/src/app/core/http/dashboard.service.ts

177 lines
7.5 KiB
TypeScript

///
/// Copyright © 2016-2020 The Thingsboard Authors
///
/// Licensed under the Apache License, Version 2.0 (the "License");
/// you may not use this file except in compliance with the License.
/// You may obtain a copy of the License at
///
/// http://www.apache.org/licenses/LICENSE-2.0
///
/// Unless required by applicable law or agreed to in writing, software
/// distributed under the License is distributed on an "AS IS" BASIS,
/// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
/// See the License for the specific language governing permissions and
/// limitations under the License.
///
import { Inject, Injectable } from '@angular/core';
import { defaultHttpOptions, defaultHttpOptionsFromConfig, RequestConfig } from './http-utils';
import { Observable } from 'rxjs';
import { HttpClient } from '@angular/common/http';
import { PageLink } from '@shared/models/page/page-link';
import { PageData } from '@shared/models/page/page-data';
import { Dashboard, DashboardInfo } from '@shared/models/dashboard.models';
import { WINDOW } from '@core/services/window.service';
import { NavigationEnd, Router } from '@angular/router';
import { filter, map, publishReplay, refCount } from 'rxjs/operators';
// @dynamic
@Injectable({
providedIn: 'root'
})
export class DashboardService {
stDiffObservable: Observable<number>;
currentUrl: string;
constructor(
private http: HttpClient,
private router: Router,
@Inject(WINDOW) private window: Window
) {
this.currentUrl = this.router.url.split('?')[0];
this.router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe(
() => {
const newUrl = this.router.url.split('?')[0];
if (this.currentUrl !== newUrl) {
this.stDiffObservable = null;
this.currentUrl = newUrl;
}
}
);
}
public getTenantDashboards(pageLink: PageLink, config?: RequestConfig): Observable<PageData<DashboardInfo>> {
return this.http.get<PageData<DashboardInfo>>(`/api/tenant/dashboards${pageLink.toQuery()}`,
defaultHttpOptionsFromConfig(config));
}
public getTenantDashboardsByTenantId(tenantId: string, pageLink: PageLink,
config?: RequestConfig): Observable<PageData<DashboardInfo>> {
return this.http.get<PageData<DashboardInfo>>(`/api/tenant/${tenantId}/dashboards${pageLink.toQuery()}`,
defaultHttpOptionsFromConfig(config));
}
public getCustomerDashboards(customerId: string, pageLink: PageLink, config?: RequestConfig): Observable<PageData<DashboardInfo>> {
return this.http.get<PageData<DashboardInfo>>(`/api/customer/${customerId}/dashboards${pageLink.toQuery()}`,
defaultHttpOptionsFromConfig(config));
}
public getDashboard(dashboardId: string, config?: RequestConfig): Observable<Dashboard> {
return this.http.get<Dashboard>(`/api/dashboard/${dashboardId}`, defaultHttpOptionsFromConfig(config));
}
public getDashboardInfo(dashboardId: string, config?: RequestConfig): Observable<DashboardInfo> {
return this.http.get<DashboardInfo>(`/api/dashboard/info/${dashboardId}`, defaultHttpOptionsFromConfig(config));
}
public saveDashboard(dashboard: Dashboard, config?: RequestConfig): Observable<Dashboard> {
return this.http.post<Dashboard>('/api/dashboard', dashboard, defaultHttpOptionsFromConfig(config));
}
public deleteDashboard(dashboardId: string, config?: RequestConfig) {
return this.http.delete(`/api/dashboard/${dashboardId}`, defaultHttpOptionsFromConfig(config));
}
public assignDashboardToCustomer(customerId: string, dashboardId: string,
config?: RequestConfig): Observable<Dashboard> {
return this.http.post<Dashboard>(`/api/customer/${customerId}/dashboard/${dashboardId}`,
null, defaultHttpOptionsFromConfig(config));
}
public unassignDashboardFromCustomer(customerId: string, dashboardId: string,
config?: RequestConfig) {
return this.http.delete(`/api/customer/${customerId}/dashboard/${dashboardId}`, defaultHttpOptionsFromConfig(config));
}
public makeDashboardPublic(dashboardId: string, config?: RequestConfig): Observable<Dashboard> {
return this.http.post<Dashboard>(`/api/customer/public/dashboard/${dashboardId}`, null,
defaultHttpOptionsFromConfig(config));
}
public makeDashboardPrivate(dashboardId: string, config?: RequestConfig): Observable<Dashboard> {
return this.http.delete<Dashboard>(`/api/customer/public/dashboard/${dashboardId}`,
defaultHttpOptionsFromConfig(config));
}
public updateDashboardCustomers(dashboardId: string, customerIds: Array<string>,
config?: RequestConfig): Observable<Dashboard> {
return this.http.post<Dashboard>(`/api/dashboard/${dashboardId}/customers`, customerIds,
defaultHttpOptionsFromConfig(config));
}
public addDashboardCustomers(dashboardId: string, customerIds: Array<string>,
config?: RequestConfig): Observable<Dashboard> {
return this.http.post<Dashboard>(`/api/dashboard/${dashboardId}/customers/add`, customerIds,
defaultHttpOptionsFromConfig(config));
}
public removeDashboardCustomers(dashboardId: string, customerIds: Array<string>,
config?: RequestConfig): Observable<Dashboard> {
return this.http.post<Dashboard>(`/api/dashboard/${dashboardId}/customers/remove`, customerIds,
defaultHttpOptionsFromConfig(config));
}
public getPublicDashboardLink(dashboard: DashboardInfo): string | null {
if (dashboard && dashboard.assignedCustomers && dashboard.assignedCustomers.length > 0) {
const publicCustomers = dashboard.assignedCustomers
.filter(customerInfo => customerInfo.public);
if (publicCustomers.length > 0) {
const publicCustomerId = publicCustomers[0].customerId.id;
let url = this.window.location.protocol + '//' + this.window.location.hostname;
const port = this.window.location.port;
if (port !== '80' && port !== '443') {
url += ':' + port;
}
url += `/dashboard/${dashboard.id.id}?publicId=${publicCustomerId}`;
return url;
}
}
return null;
}
public getServerTimeDiff(): Observable<number> {
if (!this.stDiffObservable) {
const url = '/api/dashboard/serverTime';
const ct1 = Date.now();
this.stDiffObservable = this.http.get<number>(url, defaultHttpOptions(true)).pipe(
map((st) => {
const ct2 = Date.now();
const stDiff = Math.ceil(st - (ct1 + ct2) / 2);
return stDiff;
}),
publishReplay(1),
refCount()
);
}
return this.stDiffObservable;
}
public getEdgeDashboards(edgeId: string, pageLink: PageLink, type: string = '',
config?: RequestConfig): Observable<PageData<DashboardInfo>> {
return this.http.get<PageData<DashboardInfo>>(`/api/edge/${edgeId}/dashboards${pageLink.toQuery()}&type=${type}`,
defaultHttpOptionsFromConfig(config))
}
public assignDashboardToEdge(edgeId: string, dashboardId: string,
config?: RequestConfig): Observable<Dashboard> {
return this.http.post<Dashboard>(`/api/edge/${edgeId}/dashboard/${dashboardId}`,
null, defaultHttpOptionsFromConfig(config));
}
public unassignDashboardFromEdge(edgeId: string, dashboardId: string, config?: RequestConfig) {
return this.http.delete(`/api/edge/${edgeId}/dashboard/${dashboardId}`, defaultHttpOptionsFromConfig(config));
}
}