Adding new components with portal-FE-common
[portal.git] / portal-FE-common / src / app / shared / plugin / transfer-state.service.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 { Inject, Injectable, PLATFORM_ID } from '@angular/core';
40 import { makeStateKey, TransferState } from '@angular/platform-browser';
41 import { isPlatformBrowser, isPlatformServer } from '@angular/common';
42 import { of } from 'rxjs';
43 import { tap } from 'rxjs/operators';
44
45 let isBrowser: boolean;
46 let isServer: boolean;
47 let transferState: TransferState;
48
49 @Injectable({
50   providedIn: 'root'
51 })
52 export class TransferStateService {
53   constructor(
54     private state: TransferState,
55     @Inject(PLATFORM_ID) private platformId: any
56   ) {
57     transferState = state;
58     isBrowser = isPlatformBrowser(this.platformId);
59     isServer = isPlatformServer(this.platformId);
60   }
61 }
62
63 export const preserveServerState = (
64   keyName: string,
65   emptyResult: any = null
66 ) => {
67   const key = makeStateKey(keyName);
68   return (target: any, propertyKey: string, descriptor: PropertyDescriptor) => {
69     const method = descriptor.value;
70     descriptor.value = function() {
71       if (isBrowser && transferState.hasKey(key)) {
72         const state = transferState.get(key, emptyResult);
73         return of(state);
74       }
75
76       return method.apply(this, arguments).pipe(
77         tap(res => {
78          // if (isServer) {
79             transferState.set(key, res);
80         //  }
81         })
82       );
83     };
84   };
85 };