Adding new components with portal-FE-common
[portal.git] / portal-FE-common / src / app / shared / plugin / plugin.module.ts
1 /*-
2  * ============LICENSE_START==========================================
3  * ONAP Portal
4  * ===================================================================
5  * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6  * ===================================================================
7  *
8  * Unless otherwise specified, all software contained herein is licensed
9  * under the Apache License, Version 2.0 (the "License");
10  * you may not use this software except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *             http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  * Unless otherwise specified, all documentation contained herein is licensed
22  * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
23  * you may not use this documentation except in compliance with the License.
24  * You may obtain a copy of the License at
25  *
26  *             https://creativecommons.org/licenses/by/4.0/
27  *
28  * Unless required by applicable law or agreed to in writing, documentation
29  * distributed under the License is distributed on an "AS IS" BASIS,
30  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
31  * See the License for the specific language governing permissions and
32  * limitations under the License.
33  *
34  * ============LICENSE_END============================================
35  *
36  * 
37  */
38  
39 import {
40   BrowserModule,
41   BrowserTransferStateModule, TransferState
42 } from '@angular/platform-browser';
43 import { APP_INITIALIZER, NgModule, APP_BOOTSTRAP_LISTENER } from '@angular/core';
44 import { HttpClientModule } from '@angular/common/http';
45 import { DynamicWidgetModule } from './dynamic-widget/dynamic-widget.module';
46
47
48
49 import { ClientPluginLoaderService } from './plugin-loader/client-plugin-loader.service';
50 import { PluginsConfigProvider } from './plugins-config.provider';
51 import { TransferStateService } from './transfer-state.service';
52 import { PluginLoaderService } from './plugin-loader/plugin-loader.service';
53 import { PluginComponent } from './plugin.component';
54 import { ListWidgetComponent } from './dynamic-widget/list-widget/list-widget.component';
55
56 import { config } from 'rxjs';
57
58 @NgModule({
59   declarations: [PluginComponent],
60   imports: [
61     HttpClientModule,
62     //BrowserModule.withServerTransition({ appId: 'serverApp' }),
63     BrowserTransferStateModule
64   ],
65   providers: [
66     { provide: PluginLoaderService, useClass: ClientPluginLoaderService },
67     //PluginsConfigProvider,
68     TransferStateService,
69     {
70       provide: APP_BOOTSTRAP_LISTENER,
71       useFactory: (provider: PluginsConfigProvider) => () =>
72         provider
73           .loadConfig()
74           .toPromise()
75           .then(config => {
76             provider.config = config;
77             console.log(config);
78           }
79           ),
80       multi: true,
81       deps: [PluginsConfigProvider]
82     }
83   ],
84   bootstrap: [PluginComponent],
85   exports: [PluginComponent]
86 })
87 export class PluginModule {
88   constructor(transferStateService: TransferStateService) {}
89 }