barsa-novin-ray-core 1.0.430 → 1.0.433

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,6 @@
1
- import { ChangeDetectionStrategy, Component, ViewChild } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, ViewChild, ViewContainerRef } from '@angular/core';
2
2
  import { NavigationEnd, NavigationStart, RouterEvent } from '@angular/router';
3
+ import { tap } from 'rxjs';
3
4
  import { BarsaApi, PageBaseComponent } from '../abstract-classes';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@angular/common";
@@ -20,11 +21,25 @@ export class RootPortalComponent extends PageBaseComponent {
20
21
  }
21
22
  });
22
23
  }
24
+ addFooter(pageData) {
25
+ if (!pageData?.Footer) {
26
+ return;
27
+ }
28
+ const footerComponent = pageData.Footer.Component;
29
+ this.getComponentFactory(footerComponent).pipe(tap((controlUi) => {
30
+ controlUi.instance.settings = footerComponent.Settings;
31
+ controlUi.instance.activatedRoute = this._activatedRoute;
32
+ if (this.footerRefVcr) {
33
+ this.footerRefVcr.insert(controlUi.hostView);
34
+ }
35
+ }));
36
+ }
23
37
  renderPlaceHolders(pageData) {
24
38
  super.renderPlaceHolders(pageData);
25
39
  if (!this._portalService.userLoggedIn) {
26
40
  return;
27
41
  }
42
+ this.addFooter(pageData);
28
43
  const jsfiles = [];
29
44
  const cssfiles = [];
30
45
  Object.keys(BarsaApi.LoginFormData).forEach((key) => {
@@ -56,55 +71,57 @@ export class RootPortalComponent extends PageBaseComponent {
56
71
  }
57
72
  }
58
73
  RootPortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: RootPortalComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
59
- RootPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: RootPortalComponent, selector: "bnrc-root-portal", viewQueries: [{ propertyName: "sectionRef", first: true, predicate: ["sectionRef"], descendants: true }, { propertyName: "footerRef", first: true, predicate: ["footerRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: `
60
- <div *ngIf="imageUrl" id="headerSpaceHolder" #headerSpaceHolder>
61
- <div id="bgOuterHolder" #bgOuterHolder>
62
- <div id="bgInnerHolder" style="height: 100vh">
63
- <div class="backgroundImage" id="backgroundImage">
64
- <img class="picture" [src]="imageUrl" loading="lazy" />
65
- <span id="backgroundImageOverlay" class="overlay"></span>
66
- </div>
67
- </div>
68
- </div>
69
- </div>
70
- <section class="section" id="mainpage" #sectionRef>
71
- <div #containerRef></div>
72
- </section>
73
- <div class="page-wrapper">
74
- <router-outlet></router-outlet>
75
- </div>
76
- <footer #footerRef></footer>
74
+ RootPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: RootPortalComponent, selector: "bnrc-root-portal", viewQueries: [{ propertyName: "sectionRef", first: true, predicate: ["sectionRef"], descendants: true }, { propertyName: "footerRefVcr", first: true, predicate: ["footerRef"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: `
75
+ <div *ngIf="imageUrl" id="headerSpaceHolder" #headerSpaceHolder>
76
+ <div id="bgOuterHolder" #bgOuterHolder>
77
+ <div id="bgInnerHolder" style="height: 100vh">
78
+ <div class="backgroundImage" id="backgroundImage">
79
+ <img class="picture" [src]="imageUrl" loading="lazy" />
80
+ <span id="backgroundImageOverlay" class="overlay"></span>
81
+ </div>
82
+ </div>
83
+ </div>
84
+ </div>
85
+ <section class="section" id="mainpage" #sectionRef>
86
+ <div #containerRef></div>
87
+ </section>
88
+ <div class="page-wrapper">
89
+ <router-outlet></router-outlet>
90
+ </div>
91
+ <!-- <footer #footerRef></footer> -->
92
+ <ng-container #footerRef></ng-container>
77
93
  `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
78
94
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: RootPortalComponent, decorators: [{
79
95
  type: Component,
80
96
  args: [{
81
97
  selector: 'bnrc-root-portal',
82
- template: `
83
- <div *ngIf="imageUrl" id="headerSpaceHolder" #headerSpaceHolder>
84
- <div id="bgOuterHolder" #bgOuterHolder>
85
- <div id="bgInnerHolder" style="height: 100vh">
86
- <div class="backgroundImage" id="backgroundImage">
87
- <img class="picture" [src]="imageUrl" loading="lazy" />
88
- <span id="backgroundImageOverlay" class="overlay"></span>
89
- </div>
90
- </div>
91
- </div>
92
- </div>
93
- <section class="section" id="mainpage" #sectionRef>
94
- <div #containerRef></div>
95
- </section>
96
- <div class="page-wrapper">
97
- <router-outlet></router-outlet>
98
- </div>
99
- <footer #footerRef></footer>
98
+ template: `
99
+ <div *ngIf="imageUrl" id="headerSpaceHolder" #headerSpaceHolder>
100
+ <div id="bgOuterHolder" #bgOuterHolder>
101
+ <div id="bgInnerHolder" style="height: 100vh">
102
+ <div class="backgroundImage" id="backgroundImage">
103
+ <img class="picture" [src]="imageUrl" loading="lazy" />
104
+ <span id="backgroundImageOverlay" class="overlay"></span>
105
+ </div>
106
+ </div>
107
+ </div>
108
+ </div>
109
+ <section class="section" id="mainpage" #sectionRef>
110
+ <div #containerRef></div>
111
+ </section>
112
+ <div class="page-wrapper">
113
+ <router-outlet></router-outlet>
114
+ </div>
115
+ <!-- <footer #footerRef></footer> -->
116
+ <ng-container #footerRef></ng-container>
100
117
  `,
101
118
  changeDetection: ChangeDetectionStrategy.OnPush
102
119
  }]
103
120
  }], propDecorators: { sectionRef: [{
104
121
  type: ViewChild,
105
122
  args: ['sectionRef']
106
- }], footerRef: [{
123
+ }], footerRefVcr: [{
107
124
  type: ViewChild,
108
- args: ['footerRef']
125
+ args: ['footerRef', { read: ViewContainerRef }]
109
126
  }] } });
110
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9vdC1wb3J0YWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etbm92aW4tcmF5LWNvcmUvc3JjL2xpYi9yb290LXBvcnRhbC9yb290LXBvcnRhbC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBc0IsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWxHLE9BQU8sRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLFdBQVcsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRzlFLE9BQU8sRUFBRSxRQUFRLEVBQUUsaUJBQWlCLEVBQWlCLE1BQU0scUJBQXFCLENBQUM7Ozs7QUEwQmpGLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxpQkFBaUI7SUF2QjFEOztRQTRCSSxXQUFNLEdBQUcsSUFBSSxDQUFDO0tBaURqQjtJQS9DRyxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBRWpCLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ3BDLElBQUksS0FBSyxZQUFZLGVBQWUsSUFBSSxLQUFLLFlBQVksV0FBVyxFQUFFO2dCQUNsRSxJQUFJLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUM3QztZQUNELElBQUksS0FBSyxZQUFZLGFBQWEsSUFBSSxLQUFLLFlBQVksV0FBVyxFQUFFO2dCQUNoRSxJQUFJLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUMzQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUNTLGtCQUFrQixDQUFDLFFBQThCO1FBQ3ZELEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNuQyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLEVBQUU7WUFDbkMsT0FBTztTQUNWO1FBQ0QsTUFBTSxPQUFPLEdBQWEsRUFBRSxDQUFDO1FBQzdCLE1BQU0sUUFBUSxHQUFhLEVBQUUsQ0FBQztRQUM5QixNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUNoRCxJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLEVBQUU7Z0JBQzFCLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO2FBQzdDO1lBQ0QsSUFBSSxHQUFHLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxFQUFFO2dCQUMzQixRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQzthQUM5QztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUNwQixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQ3RCO1FBQ0QsSUFBSSxRQUFRLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUNyQixRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7Z0JBQ25CLFFBQVEsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsV0FBVyxFQUFFLGdCQUFnQixDQUFDLGdDQUFnQyxDQUFDLENBQUM7WUFDckcsQ0FBQyxDQUFDLENBQUM7U0FDTjtRQUNELE1BQU0sRUFBRSxZQUFZLEVBQUUsR0FBRyxJQUFJLENBQUMsUUFBZSxDQUFDO1FBQzlDLElBQUksWUFBWSxFQUFFO1lBQ2QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsd0JBQXdCLENBQUMsQ0FBQztZQUMzRSxJQUFJLENBQUMsUUFBUSxHQUFHLDJCQUEyQixZQUFZLG1CQUFtQixDQUFDO1lBQzNFLDRCQUE0QjtZQUM1Qiw4QkFBOEI7WUFDOUIsb0JBQW9CO1lBRXBCLEtBQUs7WUFDTCxnRkFBZ0Y7U0FDbkY7SUFDTCxDQUFDOztnSEFyRFEsbUJBQW1CO29HQUFuQixtQkFBbUIsa1JBckJsQjs7Ozs7Ozs7Ozs7Ozs7Ozs7O0tBa0JUOzJGQUdRLG1CQUFtQjtrQkF2Qi9CLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FrQlQ7b0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEOzhCQUU0QixVQUFVO3NCQUFsQyxTQUFTO3VCQUFDLFlBQVk7Z0JBQ0MsU0FBUztzQkFBaEMsU0FBUzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgT25Jbml0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IE5hdmlnYXRpb25FbmQsIE5hdmlnYXRpb25TdGFydCwgUm91dGVyRXZlbnQgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcblxyXG5pbXBvcnQgeyBCYXJzYUFwaSwgUGFnZUJhc2VDb21wb25lbnQsIFBhZ2VEYXRhTW9kZWwgfSBmcm9tICcuLi9hYnN0cmFjdC1jbGFzc2VzJztcclxuZGVjbGFyZSBjb25zdCBoZWFkOiBhbnk7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYm5yYy1yb290LXBvcnRhbCcsXHJcbiAgICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxkaXYgKm5nSWY9XCJpbWFnZVVybFwiIGlkPVwiaGVhZGVyU3BhY2VIb2xkZXJcIiAjaGVhZGVyU3BhY2VIb2xkZXI+XHJcbiAgICAgICAgICAgIDxkaXYgaWQ9XCJiZ091dGVySG9sZGVyXCIgI2JnT3V0ZXJIb2xkZXI+XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGlkPVwiYmdJbm5lckhvbGRlclwiIHN0eWxlPVwiaGVpZ2h0OiAxMDB2aFwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJiYWNrZ3JvdW5kSW1hZ2VcIiBpZD1cImJhY2tncm91bmRJbWFnZVwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8aW1nIGNsYXNzPVwicGljdHVyZVwiIFtzcmNdPVwiaW1hZ2VVcmxcIiBsb2FkaW5nPVwibGF6eVwiIC8+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuIGlkPVwiYmFja2dyb3VuZEltYWdlT3ZlcmxheVwiIGNsYXNzPVwib3ZlcmxheVwiPjwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8c2VjdGlvbiBjbGFzcz1cInNlY3Rpb25cIiBpZD1cIm1haW5wYWdlXCIgI3NlY3Rpb25SZWY+XHJcbiAgICAgICAgICAgIDxkaXYgI2NvbnRhaW5lclJlZj48L2Rpdj5cclxuICAgICAgICA8L3NlY3Rpb24+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cInBhZ2Utd3JhcHBlclwiPlxyXG4gICAgICAgICAgICA8cm91dGVyLW91dGxldD48L3JvdXRlci1vdXRsZXQ+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGZvb3RlciAjZm9vdGVyUmVmPjwvZm9vdGVyPlxyXG4gICAgYCxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSb290UG9ydGFsQ29tcG9uZW50IGV4dGVuZHMgUGFnZUJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gICAgQFZpZXdDaGlsZCgnc2VjdGlvblJlZicpIHNlY3Rpb25SZWY6IEVsZW1lbnRSZWY7XHJcbiAgICBAVmlld0NoaWxkKCdmb290ZXJSZWYnKSBmb290ZXJSZWY6IEVsZW1lbnRSZWY7XHJcbiAgICBwb3J0YWxMb2FkaW5nJDogT2JzZXJ2YWJsZTxib29sZWFuPjtcclxuICAgIG1vZHVsZXM6IGFueTtcclxuICAgIGlzUm9vdCA9IHRydWU7XHJcbiAgICBpbWFnZVVybDogc3RyaW5nO1xyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcclxuXHJcbiAgICAgICAgdGhpcy5fcm91dGVyLmV2ZW50cy5zdWJzY3JpYmUoKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgICAgIGlmIChldmVudCBpbnN0YW5jZW9mIE5hdmlnYXRpb25TdGFydCAmJiBldmVudCBpbnN0YW5jZW9mIFJvdXRlckV2ZW50KSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLl9wb3J0YWxTZXJ2aWNlLm5hdmlhdGlvblN0YXJ0KGV2ZW50KTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICBpZiAoZXZlbnQgaW5zdGFuY2VvZiBOYXZpZ2F0aW9uRW5kICYmIGV2ZW50IGluc3RhbmNlb2YgUm91dGVyRXZlbnQpIHtcclxuICAgICAgICAgICAgICAgIHRoaXMuX3BvcnRhbFNlcnZpY2UubmF2aWF0aW9uRW5kKGV2ZW50KTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG4gICAgcHJvdGVjdGVkIHJlbmRlclBsYWNlSG9sZGVycyhwYWdlRGF0YTogUGFnZURhdGFNb2RlbCB8IG51bGwpOiB2b2lkIHtcclxuICAgICAgICBzdXBlci5yZW5kZXJQbGFjZUhvbGRlcnMocGFnZURhdGEpO1xyXG4gICAgICAgIGlmICghdGhpcy5fcG9ydGFsU2VydmljZS51c2VyTG9nZ2VkSW4pIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBjb25zdCBqc2ZpbGVzOiBzdHJpbmdbXSA9IFtdO1xyXG4gICAgICAgIGNvbnN0IGNzc2ZpbGVzOiBzdHJpbmdbXSA9IFtdO1xyXG4gICAgICAgIE9iamVjdC5rZXlzKEJhcnNhQXBpLkxvZ2luRm9ybURhdGEpLmZvckVhY2goKGtleSkgPT4ge1xyXG4gICAgICAgICAgICBpZiAoa2V5LnN0YXJ0c1dpdGgoJ0pTRmlsZScpKSB7XHJcbiAgICAgICAgICAgICAgICBqc2ZpbGVzLnB1c2goQmFyc2FBcGkuTG9naW5Gb3JtRGF0YVtrZXldKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICBpZiAoa2V5LnN0YXJ0c1dpdGgoJ0NTU0ZpbGUnKSkge1xyXG4gICAgICAgICAgICAgICAgY3NzZmlsZXMucHVzaChCYXJzYUFwaS5Mb2dpbkZvcm1EYXRhW2tleV0pO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgaWYgKGpzZmlsZXMubGVuZ3RoID4gMCkge1xyXG4gICAgICAgICAgICBoZWFkLmxvYWQoanNmaWxlcyk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChjc3NmaWxlcy5sZW5ndGggPiAwKSB7XHJcbiAgICAgICAgICAgIGNzc2ZpbGVzLmZvckVhY2goKGMpID0+IHtcclxuICAgICAgICAgICAgICAgIGRvY3VtZW50LmhlYWQuaW5zZXJ0QWRqYWNlbnRIVE1MKCdiZWZvcmVlbmQnLCBgIDxsaW5rIGhyZWY9XCIke2N9XCIgcmVsPVwic3R5bGVzaGVldFwiIG5vcG9ydGFsIC8+YCk7XHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH1cclxuICAgICAgICBjb25zdCB7IEJhY2tncm91bmRJZCB9ID0gdGhpcy5wYWdlRGF0YSBhcyBhbnk7XHJcbiAgICAgICAgaWYgKEJhY2tncm91bmRJZCkge1xyXG4gICAgICAgICAgICB0aGlzLl9yZW5kZXJlcjIuYWRkQ2xhc3ModGhpcy5fZWwubmF0aXZlRWxlbWVudCwgJ3Jvb3QtY3VzdG9tLWJhY2tncm91bmQnKTtcclxuICAgICAgICAgICAgdGhpcy5pbWFnZVVybCA9IGAvSUguYXNoeD90eT1JRCZtb0lkPSZpZD0ke0JhY2tncm91bmRJZH0mc2k9MTkyMCZzaWg9MTA4MGA7XHJcbiAgICAgICAgICAgIC8vIHRoaXMuX3JlbmRlcmVyMi5zZXRTdHlsZShcclxuICAgICAgICAgICAgLy8gICAgIHRoaXMuX2VsLm5hdGl2ZUVsZW1lbnQsXHJcbiAgICAgICAgICAgIC8vICAgICAnYmFja2dyb3VuZCcsXHJcblxyXG4gICAgICAgICAgICAvLyApO1xyXG4gICAgICAgICAgICAvLyB0aGlzLl9yZW5kZXJlcjIuc2V0U3R5bGUodGhpcy5fZWwubmF0aXZlRWxlbWVudCwgJ2JhY2tncm91bmQtc2l6ZScsIGBjb3ZlcmApO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxufVxyXG4iXX0=
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root-portal.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-novin-ray-core/src/lib/root-portal/root-portal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\n\nimport { NavigationEnd, NavigationStart, RouterEvent } from '@angular/router';\nimport { Observable, tap } from 'rxjs';\n\nimport { BarsaApi, PageBaseComponent, PageDataModel } from '../abstract-classes';\ndeclare const head: any;\n\n@Component({\n    selector: 'bnrc-root-portal',\n    template: `\n        <div *ngIf=\"imageUrl\" id=\"headerSpaceHolder\" #headerSpaceHolder>\n            <div id=\"bgOuterHolder\" #bgOuterHolder>\n                <div id=\"bgInnerHolder\" style=\"height: 100vh\">\n                    <div class=\"backgroundImage\" id=\"backgroundImage\">\n                        <img class=\"picture\" [src]=\"imageUrl\" loading=\"lazy\" />\n                        <span id=\"backgroundImageOverlay\" class=\"overlay\"></span>\n                    </div>\n                </div>\n            </div>\n        </div>\n        <section class=\"section\" id=\"mainpage\" #sectionRef>\n            <div #containerRef></div>\n        </section>\n        <div class=\"page-wrapper\">\n            <router-outlet></router-outlet>\n        </div>\n        <!-- <footer #footerRef></footer> -->\n        <ng-container #footerRef></ng-container>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RootPortalComponent extends PageBaseComponent implements OnInit {\n    @ViewChild('sectionRef') sectionRef: ElementRef;\n    @ViewChild('footerRef', { read: ViewContainerRef }) footerRefVcr: ViewContainerRef;\n    portalLoading$: Observable<boolean>;\n    modules: any;\n    isRoot = true;\n    imageUrl: string;\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        this._router.events.subscribe((event) => {\n            if (event instanceof NavigationStart && event instanceof RouterEvent) {\n                this._portalService.naviationStart(event);\n            }\n            if (event instanceof NavigationEnd && event instanceof RouterEvent) {\n                this._portalService.naviationEnd(event);\n            }\n        });\n    }\n    protected addFooter(pageData: PageDataModel | null): void {\n        if (!pageData?.Footer) {\n            return;\n        }\n        const footerComponent = pageData.Footer.Component;\n        this.getComponentFactory(footerComponent).pipe(\n            tap((controlUi) => {\n                controlUi.instance.settings = footerComponent.Settings;\n                controlUi.instance.activatedRoute = this._activatedRoute;\n                if (this.footerRefVcr) {\n                    this.footerRefVcr.insert(controlUi.hostView);\n                }\n            })\n        );\n    }\n    protected renderPlaceHolders(pageData: PageDataModel | null): void {\n        super.renderPlaceHolders(pageData);\n        if (!this._portalService.userLoggedIn) {\n            return;\n        }\n        this.addFooter(pageData);\n        const jsfiles: string[] = [];\n        const cssfiles: string[] = [];\n        Object.keys(BarsaApi.LoginFormData).forEach((key) => {\n            if (key.startsWith('JSFile')) {\n                jsfiles.push(BarsaApi.LoginFormData[key]);\n            }\n            if (key.startsWith('CSSFile')) {\n                cssfiles.push(BarsaApi.LoginFormData[key]);\n            }\n        });\n        if (jsfiles.length > 0) {\n            head.load(jsfiles);\n        }\n        if (cssfiles.length > 0) {\n            cssfiles.forEach((c) => {\n                document.head.insertAdjacentHTML('beforeend', ` <link href=\"${c}\" rel=\"stylesheet\" noportal />`);\n            });\n        }\n        const { BackgroundId } = this.pageData as any;\n        if (BackgroundId) {\n            this._renderer2.addClass(this._el.nativeElement, 'root-custom-background');\n            this.imageUrl = `/IH.ashx?ty=ID&moId=&id=${BackgroundId}&si=1920&sih=1080`;\n            // this._renderer2.setStyle(\n            //     this._el.nativeElement,\n            //     'background',\n\n            // );\n            // this._renderer2.setStyle(this._el.nativeElement, 'background-size', `cover`);\n        }\n    }\n}\n"]}
@@ -10716,11 +10716,25 @@ class RootPortalComponent extends PageBaseComponent {
10716
10716
  }
10717
10717
  });
10718
10718
  }
10719
+ addFooter(pageData) {
10720
+ if (!(pageData === null || pageData === void 0 ? void 0 : pageData.Footer)) {
10721
+ return;
10722
+ }
10723
+ const footerComponent = pageData.Footer.Component;
10724
+ this.getComponentFactory(footerComponent).pipe(tap$1((controlUi) => {
10725
+ controlUi.instance.settings = footerComponent.Settings;
10726
+ controlUi.instance.activatedRoute = this._activatedRoute;
10727
+ if (this.footerRefVcr) {
10728
+ this.footerRefVcr.insert(controlUi.hostView);
10729
+ }
10730
+ }));
10731
+ }
10719
10732
  renderPlaceHolders(pageData) {
10720
10733
  super.renderPlaceHolders(pageData);
10721
10734
  if (!this._portalService.userLoggedIn) {
10722
10735
  return;
10723
10736
  }
10737
+ this.addFooter(pageData);
10724
10738
  const jsfiles = [];
10725
10739
  const cssfiles = [];
10726
10740
  Object.keys(BarsaApi.LoginFormData).forEach((key) => {
@@ -10752,56 +10766,58 @@ class RootPortalComponent extends PageBaseComponent {
10752
10766
  }
10753
10767
  }
10754
10768
  RootPortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: RootPortalComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
10755
- RootPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: RootPortalComponent, selector: "bnrc-root-portal", viewQueries: [{ propertyName: "sectionRef", first: true, predicate: ["sectionRef"], descendants: true }, { propertyName: "footerRef", first: true, predicate: ["footerRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: `
10756
- <div *ngIf="imageUrl" id="headerSpaceHolder" #headerSpaceHolder>
10757
- <div id="bgOuterHolder" #bgOuterHolder>
10758
- <div id="bgInnerHolder" style="height: 100vh">
10759
- <div class="backgroundImage" id="backgroundImage">
10760
- <img class="picture" [src]="imageUrl" loading="lazy" />
10761
- <span id="backgroundImageOverlay" class="overlay"></span>
10762
- </div>
10763
- </div>
10764
- </div>
10765
- </div>
10766
- <section class="section" id="mainpage" #sectionRef>
10767
- <div #containerRef></div>
10768
- </section>
10769
- <div class="page-wrapper">
10770
- <router-outlet></router-outlet>
10771
- </div>
10772
- <footer #footerRef></footer>
10769
+ RootPortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: RootPortalComponent, selector: "bnrc-root-portal", viewQueries: [{ propertyName: "sectionRef", first: true, predicate: ["sectionRef"], descendants: true }, { propertyName: "footerRefVcr", first: true, predicate: ["footerRef"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: `
10770
+ <div *ngIf="imageUrl" id="headerSpaceHolder" #headerSpaceHolder>
10771
+ <div id="bgOuterHolder" #bgOuterHolder>
10772
+ <div id="bgInnerHolder" style="height: 100vh">
10773
+ <div class="backgroundImage" id="backgroundImage">
10774
+ <img class="picture" [src]="imageUrl" loading="lazy" />
10775
+ <span id="backgroundImageOverlay" class="overlay"></span>
10776
+ </div>
10777
+ </div>
10778
+ </div>
10779
+ </div>
10780
+ <section class="section" id="mainpage" #sectionRef>
10781
+ <div #containerRef></div>
10782
+ </section>
10783
+ <div class="page-wrapper">
10784
+ <router-outlet></router-outlet>
10785
+ </div>
10786
+ <!-- <footer #footerRef></footer> -->
10787
+ <ng-container #footerRef></ng-container>
10773
10788
  `, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
10774
10789
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: RootPortalComponent, decorators: [{
10775
10790
  type: Component,
10776
10791
  args: [{
10777
10792
  selector: 'bnrc-root-portal',
10778
- template: `
10779
- <div *ngIf="imageUrl" id="headerSpaceHolder" #headerSpaceHolder>
10780
- <div id="bgOuterHolder" #bgOuterHolder>
10781
- <div id="bgInnerHolder" style="height: 100vh">
10782
- <div class="backgroundImage" id="backgroundImage">
10783
- <img class="picture" [src]="imageUrl" loading="lazy" />
10784
- <span id="backgroundImageOverlay" class="overlay"></span>
10785
- </div>
10786
- </div>
10787
- </div>
10788
- </div>
10789
- <section class="section" id="mainpage" #sectionRef>
10790
- <div #containerRef></div>
10791
- </section>
10792
- <div class="page-wrapper">
10793
- <router-outlet></router-outlet>
10794
- </div>
10795
- <footer #footerRef></footer>
10793
+ template: `
10794
+ <div *ngIf="imageUrl" id="headerSpaceHolder" #headerSpaceHolder>
10795
+ <div id="bgOuterHolder" #bgOuterHolder>
10796
+ <div id="bgInnerHolder" style="height: 100vh">
10797
+ <div class="backgroundImage" id="backgroundImage">
10798
+ <img class="picture" [src]="imageUrl" loading="lazy" />
10799
+ <span id="backgroundImageOverlay" class="overlay"></span>
10800
+ </div>
10801
+ </div>
10802
+ </div>
10803
+ </div>
10804
+ <section class="section" id="mainpage" #sectionRef>
10805
+ <div #containerRef></div>
10806
+ </section>
10807
+ <div class="page-wrapper">
10808
+ <router-outlet></router-outlet>
10809
+ </div>
10810
+ <!-- <footer #footerRef></footer> -->
10811
+ <ng-container #footerRef></ng-container>
10796
10812
  `,
10797
10813
  changeDetection: ChangeDetectionStrategy.OnPush
10798
10814
  }]
10799
10815
  }], propDecorators: { sectionRef: [{
10800
10816
  type: ViewChild,
10801
10817
  args: ['sectionRef']
10802
- }], footerRef: [{
10818
+ }], footerRefVcr: [{
10803
10819
  type: ViewChild,
10804
- args: ['footerRef']
10820
+ args: ['footerRef', { read: ViewContainerRef }]
10805
10821
  }] } });
10806
10822
 
10807
10823
  class AnchorScrollDirective {