2019-10-25 17:50:12 +03:00
|
|
|
///
|
2022-01-17 14:07:46 +02:00
|
|
|
/// Copyright © 2016-2022 The Thingsboard Authors
|
2019-10-25 17:50:12 +03:00
|
|
|
///
|
|
|
|
|
/// 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.
|
|
|
|
|
///
|
|
|
|
|
|
2021-12-06 12:54:48 +02:00
|
|
|
import { Inject, Injectable, Type } from '@angular/core';
|
2019-10-25 17:50:12 +03:00
|
|
|
import { Observable } from 'rxjs';
|
2020-02-10 13:15:29 +02:00
|
|
|
import { MatDialog } from '@angular/material/dialog';
|
2019-10-25 17:50:12 +03:00
|
|
|
import { TranslateService } from '@ngx-translate/core';
|
|
|
|
|
import { AuthService } from '@core/auth/auth.service';
|
|
|
|
|
import { DynamicComponentFactoryService } from '@core/services/dynamic-component-factory.service';
|
|
|
|
|
import { CommonModule } from '@angular/common';
|
|
|
|
|
import { mergeMap, tap } from 'rxjs/operators';
|
|
|
|
|
import { CustomDialogComponent } from './custom-dialog.component';
|
|
|
|
|
import {
|
|
|
|
|
CustomDialogContainerComponent,
|
|
|
|
|
CustomDialogContainerData
|
|
|
|
|
} from '@home/components/widget/dialog/custom-dialog-container.component';
|
2021-12-06 12:54:48 +02:00
|
|
|
import { SHARED_MODULE_TOKEN } from '@shared/components/tokens';
|
2022-10-05 14:46:56 +03:00
|
|
|
import { HOME_COMPONENTS_MODULE_TOKEN, SHARED_HOME_COMPONENTS_MODULE_TOKEN } from '@home/components/tokens';
|
2019-10-25 17:50:12 +03:00
|
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
|
export class CustomDialogService {
|
|
|
|
|
|
|
|
|
|
constructor(
|
|
|
|
|
private translate: TranslateService,
|
|
|
|
|
private authService: AuthService,
|
|
|
|
|
private dynamicComponentFactoryService: DynamicComponentFactoryService,
|
2021-12-06 12:54:48 +02:00
|
|
|
@Inject(SHARED_MODULE_TOKEN) private sharedModule: Type<any>,
|
|
|
|
|
@Inject(SHARED_HOME_COMPONENTS_MODULE_TOKEN) private sharedHomeComponentsModule: Type<any>,
|
2022-10-05 14:46:56 +03:00
|
|
|
@Inject(HOME_COMPONENTS_MODULE_TOKEN) private homeComponentsModule: Type<any>,
|
2019-10-25 17:50:12 +03:00
|
|
|
public dialog: MatDialog
|
|
|
|
|
) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
customDialog(template: string, controller: (instance: CustomDialogComponent) => void, data?: any): Observable<any> {
|
|
|
|
|
return this.dynamicComponentFactoryService.createDynamicComponentFactory(
|
|
|
|
|
class CustomDialogComponentInstance extends CustomDialogComponent {},
|
|
|
|
|
template,
|
2022-10-05 14:46:56 +03:00
|
|
|
[this.sharedModule, CommonModule, this.sharedHomeComponentsModule, this.homeComponentsModule]).pipe(
|
2019-10-25 17:50:12 +03:00
|
|
|
mergeMap((factory) => {
|
|
|
|
|
const dialogData: CustomDialogContainerData = {
|
|
|
|
|
controller,
|
|
|
|
|
customComponentFactory: factory,
|
|
|
|
|
data
|
|
|
|
|
};
|
|
|
|
|
return this.dialog.open<CustomDialogContainerComponent, CustomDialogContainerData, any>(
|
|
|
|
|
CustomDialogContainerComponent,
|
|
|
|
|
{
|
|
|
|
|
disableClose: true,
|
|
|
|
|
panelClass: ['tb-dialog', 'tb-fullscreen-dialog'],
|
|
|
|
|
data: dialogData
|
|
|
|
|
}).afterClosed().pipe(
|
|
|
|
|
tap(() => {
|
|
|
|
|
this.dynamicComponentFactoryService.destroyDynamicComponentFactory(factory);
|
|
|
|
|
})
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|