@posiwise/shared-components 0.0.143 → 0.0.144
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.
- package/esm2022/lib/pw-tabs/pw-tabs.component.mjs +35 -4
- package/esm2022/lib/shared-components.module.mjs +6 -4
- package/fesm2022/posiwise-shared-components.mjs +39 -6
- package/fesm2022/posiwise-shared-components.mjs.map +1 -1
- package/lib/pw-tabs/pw-tabs.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -16,20 +16,51 @@ export class PwTabsComponent extends AppBaseComponent {
|
|
|
16
16
|
if (this.withSubscription) {
|
|
17
17
|
this.getUserSubscription().subscribe((subscription) => {
|
|
18
18
|
this.items.forEach(item => {
|
|
19
|
-
// prepends the subscription slug to the route
|
|
20
|
-
item.routerLink
|
|
19
|
+
// prepends the subscription slug to the route while keeping routerLink as an array
|
|
20
|
+
if (Array.isArray(item.routerLink) && item.routerLink.length > 0) {
|
|
21
|
+
const originalRoute = item.routerLink[0];
|
|
22
|
+
item.routerLink = [`/${subscription?.slug}${originalRoute}`];
|
|
23
|
+
}
|
|
21
24
|
item.visible = item?.state
|
|
22
25
|
? this.permissionService.evaluatePermissions(item.state['permission'], PermissionService.selectedProduct?.feature_key, PermissionService.selectedProduct?.permission_key)
|
|
23
26
|
: item.visible;
|
|
24
27
|
});
|
|
28
|
+
this.updateActiveTab();
|
|
25
29
|
});
|
|
26
30
|
}
|
|
31
|
+
else {
|
|
32
|
+
// For non-subscription tabs, update active tab after view init
|
|
33
|
+
setTimeout(() => this.updateActiveTab(), 0);
|
|
34
|
+
}
|
|
27
35
|
this.routeEventSubscription = this.router.events.subscribe(e => {
|
|
28
36
|
if (e instanceof NavigationEnd) {
|
|
29
|
-
this.
|
|
37
|
+
this.updateActiveTab();
|
|
30
38
|
}
|
|
31
39
|
});
|
|
32
40
|
}
|
|
41
|
+
updateActiveTab() {
|
|
42
|
+
if (!this.tabInstance || !this.items.length) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
const currentUrl = this.router.url.split('?')[0];
|
|
46
|
+
const matchedItem = this.items.find(item => {
|
|
47
|
+
if (!item.routerLink || !item.visible) {
|
|
48
|
+
return false;
|
|
49
|
+
}
|
|
50
|
+
const routePath = Array.isArray(item.routerLink) ? item.routerLink[0] : item.routerLink;
|
|
51
|
+
return routePath === currentUrl;
|
|
52
|
+
});
|
|
53
|
+
if (matchedItem) {
|
|
54
|
+
// Clear previous activeItem first to ensure only one tab is active
|
|
55
|
+
this.tabInstance.activeItem = null;
|
|
56
|
+
// Then set the new activeItem
|
|
57
|
+
this.tabInstance.activeItem = matchedItem;
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
// Clear activeItem if no match found
|
|
61
|
+
this.tabInstance.activeItem = null;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
33
64
|
ngOnDestroy() {
|
|
34
65
|
this.routeEventSubscription.unsubscribe();
|
|
35
66
|
}
|
|
@@ -47,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
47
78
|
}], withSubscription: [{
|
|
48
79
|
type: Input
|
|
49
80
|
}] } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pw-tabs.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/pw-tabs/pw-tabs.component.ts","../../../../../../libs/shared-components/src/lib/pw-tabs/pw-tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { NavigationEnd } from '@angular/router';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { PermissionService } from '@posiwise/common-services';\nimport { Subscription } from '@posiwise/common-utilities';\n\nimport { MenuItem } from 'primeng/api';\nimport { TabMenu } from 'primeng/tabmenu';\nimport { Subscription as RxSubscription } from 'rxjs';\n\n@Component({\n    selector: 'pw-tabs',\n    templateUrl: './pw-tabs.component.html'\n})\nexport class PwTabsComponent extends AppBaseComponent implements OnInit, OnDestroy {\n    @Input()\n    items: MenuItem[] = [];\n\n    @ViewChild('tabMenu', { static: false })\n    tabInstance: TabMenu;\n\n    @Input()\n    withSubscription = false;\n\n    activeTab: MenuItem;\n\n    private routeEventSubscription: RxSubscription;\n\n    constructor(injector: Injector) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        if (this.withSubscription) {\n            this.getUserSubscription().subscribe((subscription: Subscription) => {\n                this.items.forEach(item => {\n                    // prepends the subscription slug to the route while keeping routerLink as an array\n                    if (Array.isArray(item.routerLink) && item.routerLink.length > 0) {\n                        const originalRoute = item.routerLink[0];\n                        item.routerLink = [`/${subscription?.slug}${originalRoute}`];\n                    }\n                    item.visible = item?.state\n                        ? this.permissionService.evaluatePermissions(\n                              item.state['permission'],\n                              PermissionService.selectedProduct?.feature_key,\n                              PermissionService.selectedProduct?.permission_key\n                          )\n                        : item.visible;\n                });\n                this.updateActiveTab();\n            });\n        } else {\n            // For non-subscription tabs, update active tab after view init\n            setTimeout(() => this.updateActiveTab(), 0);\n        }\n\n        this.routeEventSubscription = this.router.events.subscribe(e => {\n            if (e instanceof NavigationEnd) {\n                this.updateActiveTab();\n            }\n        });\n    }\n\n    private updateActiveTab(): void {\n        if (!this.tabInstance || !this.items.length) {\n            return;\n        }\n\n        const currentUrl = this.router.url.split('?')[0];\n        const matchedItem = this.items.find(item => {\n            if (!item.routerLink || !item.visible) {\n                return false;\n            }\n            const routePath = Array.isArray(item.routerLink) ? item.routerLink[0] : item.routerLink;\n            return routePath === currentUrl;\n        });\n\n        if (matchedItem) {\n            // Clear previous activeItem first to ensure only one tab is active\n            this.tabInstance.activeItem = null;\n            // Then set the new activeItem\n            this.tabInstance.activeItem = matchedItem;\n        } else {\n            // Clear activeItem if no match found\n            this.tabInstance.activeItem = null;\n        }\n    }\n\n    override ngOnDestroy() {\n        this.routeEventSubscription.unsubscribe();\n    }\n}\n","<div class=\"container-fluid pw-tab overflow-hidden\">\n  <p-tabMenu [model]=\"items\"\n    #tabMenu></p-tabMenu>\n  <div class=\"dashboard\">\n    <div class=\"dashboard-body\">\n      <router-outlet></router-outlet>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -108,7 +108,8 @@ export class SharedComponentsModule {
|
|
|
108
108
|
ProgressSpinnerModule,
|
|
109
109
|
AutoCompleteModule,
|
|
110
110
|
ImageCropperModule,
|
|
111
|
-
UiSwitchModule, i1.NgxDaterangepickerMd, PermissionTreeComponent,
|
|
111
|
+
UiSwitchModule, i1.NgxDaterangepickerMd, PermissionTreeComponent,
|
|
112
|
+
PrivacyAndTosComponent,
|
|
112
113
|
PrivacyPolicyComponent,
|
|
113
114
|
TermsConditionsComponent,
|
|
114
115
|
SplashComponent,
|
|
@@ -181,14 +182,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
181
182
|
CommonModule,
|
|
182
183
|
NgIf,
|
|
183
184
|
FieldErrorDisplayModule,
|
|
184
|
-
ResourceSharedComponentsModule
|
|
185
|
+
ResourceSharedComponentsModule
|
|
185
186
|
],
|
|
186
187
|
exports: [
|
|
187
188
|
PasswordValidationComponent,
|
|
188
189
|
PwTabsComponent,
|
|
189
190
|
DateRangePickerComponent,
|
|
190
191
|
allModules,
|
|
191
|
-
PermissionTreeComponent,
|
|
192
|
+
PermissionTreeComponent,
|
|
193
|
+
PrivacyAndTosComponent,
|
|
192
194
|
PrivacyPolicyComponent,
|
|
193
195
|
TermsConditionsComponent,
|
|
194
196
|
SplashComponent,
|
|
@@ -206,4 +208,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
206
208
|
]
|
|
207
209
|
}]
|
|
208
210
|
}], ctorParameters: () => [] });
|
|
209
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared-components.module.js","sourceRoot":"","sources":["../../../../../libs/shared-components/src/lib/shared-components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, NgIf } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { RouterModule } from '@angular/router';\n\nimport { AppLoaderModule } from '@posiwise/app-loader';\nimport { CoreTranslocoModule } from '@posiwise/core-transloco';\nimport { DirectivesModule } from '@posiwise/directives';\nimport { PipesModule } from '@posiwise/pipes';\nimport { FieldErrorDisplayModule } from '@posiwise/utils';\n\nimport { NgxDaterangepickerMd } from 'ngx-daterangepicker-material';\nimport { ImageCropperModule } from 'ngx-image-cropper';\nimport { UiSwitchModule } from 'ngx-ui-switch';\nimport { AutoCompleteModule } from 'primeng/autocomplete';\nimport { ButtonModule } from 'primeng/button';\nimport { DropdownModule } from 'primeng/dropdown';\nimport { MultiSelectModule } from 'primeng/multiselect';\nimport { ProgressSpinnerModule } from 'primeng/progressspinner';\nimport { TableModule } from 'primeng/table';\nimport { TabMenuModule } from 'primeng/tabmenu';\n\nimport { NgbModalModule, NgbNavModule, NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';\n\nimport { AuthenticatorComponent } from './authenticator/authenticator.component';\nimport { ClearBitIconComponent } from './clearbit-icon/clearbit-icon.component';\nimport { ComingSoonComponent } from './coming-soon/coming-soon.component';\nimport { HeaderComponent } from './header/header.component';\nimport { EntityGroupComponent } from './label-management/entity-group/entity-group.component';\nimport { GroupDefinitionComponent } from './label-management/group-definition/group-definition.component';\nimport { GroupsComponent } from './label-management/groups/groups.component';\nimport { LandingPageFooterBComponent } from './landing-page-footer-b/landing-page-footer-b.component';\nimport { NumberPickerComponent } from './number-picker/number-picker.component';\nimport { PasswordValidationComponent } from './password-validation/password-validation.component';\nimport { PermissionTreeComponent } from './permission-tree/permission-tree.component';\nimport { PrivacyAndTosComponent } from './privacy-and-tos/privacy-and-tos.component';\nimport { PrivacyPolicyComponent } from './privacy-policy/privacy-policy.component';\nimport { PwTabsComponent } from './pw-tabs/pw-tabs.component';\nimport { DateRangePickerComponent } from './range-date-picker/date-range-picker.component';\nimport { ResourceSharedComponentsModule } from './resource-shared-components.module';\nimport { SplashComponent } from './splash/splash.component';\nimport { TermsConditionsComponent } from './terms-conditions/terms-conditions.component';\n\n// All modules needed for both landing page and dashboard\nconst allModules = [\n    NgbTooltipModule,\n    NgbNavModule,\n    NgbModalModule,\n    TableModule,\n    TabMenuModule,\n    ButtonModule,\n    DropdownModule,\n    MultiSelectModule,\n    ProgressSpinnerModule,\n    AutoCompleteModule,\n    ImageCropperModule,\n    UiSwitchModule,\n    NgxDaterangepickerMd.forRoot()\n];\n\n@NgModule({\n    declarations: [\n        PasswordValidationComponent,\n        PwTabsComponent,\n        DateRangePickerComponent,\n        PermissionTreeComponent,\n        PrivacyAndTosComponent,\n        PrivacyPolicyComponent,\n        TermsConditionsComponent,\n        SplashComponent,\n        AuthenticatorComponent,\n        ClearBitIconComponent,\n        ComingSoonComponent,\n\n        EntityGroupComponent,\n        GroupsComponent,\n        GroupDefinitionComponent,\n        NumberPickerComponent,\n        HeaderComponent,\n        LandingPageFooterBComponent\n    ],\n    imports: [\n        FormsModule,\n        AppLoaderModule,\n        ReactiveFormsModule,\n        DirectivesModule,\n        CoreTranslocoModule,\n        RouterModule,\n        allModules,\n        PipesModule,\n        CommonModule,\n        NgIf,\n        FieldErrorDisplayModule,\n        ResourceSharedComponentsModule,\n\n    ],\n    exports: [\n        PasswordValidationComponent,\n        PwTabsComponent,\n        DateRangePickerComponent,\n        allModules,\n        PermissionTreeComponent,        PrivacyAndTosComponent,\n        PrivacyPolicyComponent,\n        TermsConditionsComponent,\n        SplashComponent,\n        AuthenticatorComponent,\n        ClearBitIconComponent,\n        ComingSoonComponent,\n        EntityGroupComponent,\n        GroupsComponent,\n        GroupDefinitionComponent,\n        NumberPickerComponent,\n        HeaderComponent,\n        LandingPageFooterBComponent,\n        FieldErrorDisplayModule,\n        ResourceSharedComponentsModule\n    ]\n})\nexport class SharedComponentsModule {\n    constructor() {\n        console.log('🚀 SHARED COMPONENTS MODULE LOADED! - Shared UI components');\n    }\n}\n"]}
|
|
211
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared-components.module.js","sourceRoot":"","sources":["../../../../../libs/shared-components/src/lib/shared-components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, NgIf } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { RouterModule } from '@angular/router';\n\nimport { AppLoaderModule } from '@posiwise/app-loader';\nimport { CoreTranslocoModule } from '@posiwise/core-transloco';\nimport { DirectivesModule } from '@posiwise/directives';\nimport { PipesModule } from '@posiwise/pipes';\nimport { FieldErrorDisplayModule } from '@posiwise/utils';\n\nimport { NgxDaterangepickerMd } from 'ngx-daterangepicker-material';\nimport { ImageCropperModule } from 'ngx-image-cropper';\nimport { UiSwitchModule } from 'ngx-ui-switch';\nimport { AutoCompleteModule } from 'primeng/autocomplete';\nimport { ButtonModule } from 'primeng/button';\nimport { DropdownModule } from 'primeng/dropdown';\nimport { MultiSelectModule } from 'primeng/multiselect';\nimport { ProgressSpinnerModule } from 'primeng/progressspinner';\nimport { TableModule } from 'primeng/table';\nimport { TabMenuModule } from 'primeng/tabmenu';\n\nimport { NgbModalModule, NgbNavModule, NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';\n\nimport { AuthenticatorComponent } from './authenticator/authenticator.component';\nimport { ClearBitIconComponent } from './clearbit-icon/clearbit-icon.component';\nimport { ComingSoonComponent } from './coming-soon/coming-soon.component';\nimport { HeaderComponent } from './header/header.component';\nimport { EntityGroupComponent } from './label-management/entity-group/entity-group.component';\nimport { GroupDefinitionComponent } from './label-management/group-definition/group-definition.component';\nimport { GroupsComponent } from './label-management/groups/groups.component';\nimport { LandingPageFooterBComponent } from './landing-page-footer-b/landing-page-footer-b.component';\nimport { NumberPickerComponent } from './number-picker/number-picker.component';\nimport { PasswordValidationComponent } from './password-validation/password-validation.component';\nimport { PermissionTreeComponent } from './permission-tree/permission-tree.component';\nimport { PrivacyAndTosComponent } from './privacy-and-tos/privacy-and-tos.component';\nimport { PrivacyPolicyComponent } from './privacy-policy/privacy-policy.component';\nimport { PwTabsComponent } from './pw-tabs/pw-tabs.component';\nimport { DateRangePickerComponent } from './range-date-picker/date-range-picker.component';\nimport { ResourceSharedComponentsModule } from './resource-shared-components.module';\nimport { SplashComponent } from './splash/splash.component';\nimport { TermsConditionsComponent } from './terms-conditions/terms-conditions.component';\n\n// All modules needed for both landing page and dashboard\nconst allModules = [\n    NgbTooltipModule,\n    NgbNavModule,\n    NgbModalModule,\n    TableModule,\n    TabMenuModule,\n    ButtonModule,\n    DropdownModule,\n    MultiSelectModule,\n    ProgressSpinnerModule,\n    AutoCompleteModule,\n    ImageCropperModule,\n    UiSwitchModule,\n    NgxDaterangepickerMd.forRoot()\n];\n\n@NgModule({\n    declarations: [\n        PasswordValidationComponent,\n        PwTabsComponent,\n        DateRangePickerComponent,\n        PermissionTreeComponent,\n        PrivacyAndTosComponent,\n        PrivacyPolicyComponent,\n        TermsConditionsComponent,\n        SplashComponent,\n        AuthenticatorComponent,\n        ClearBitIconComponent,\n        ComingSoonComponent,\n\n        EntityGroupComponent,\n        GroupsComponent,\n        GroupDefinitionComponent,\n        NumberPickerComponent,\n        HeaderComponent,\n        LandingPageFooterBComponent\n    ],\n    imports: [\n        FormsModule,\n        AppLoaderModule,\n        ReactiveFormsModule,\n        DirectivesModule,\n        CoreTranslocoModule,\n        RouterModule,\n        allModules,\n        PipesModule,\n        CommonModule,\n        NgIf,\n        FieldErrorDisplayModule,\n        ResourceSharedComponentsModule\n    ],\n    exports: [\n        PasswordValidationComponent,\n        PwTabsComponent,\n        DateRangePickerComponent,\n        allModules,\n        PermissionTreeComponent,\n        PrivacyAndTosComponent,\n        PrivacyPolicyComponent,\n        TermsConditionsComponent,\n        SplashComponent,\n        AuthenticatorComponent,\n        ClearBitIconComponent,\n        ComingSoonComponent,\n        EntityGroupComponent,\n        GroupsComponent,\n        GroupDefinitionComponent,\n        NumberPickerComponent,\n        HeaderComponent,\n        LandingPageFooterBComponent,\n        FieldErrorDisplayModule,\n        ResourceSharedComponentsModule\n    ]\n})\nexport class SharedComponentsModule {\n    constructor() {\n        console.log('🚀 SHARED COMPONENTS MODULE LOADED! - Shared UI components');\n    }\n}\n"]}
|
|
@@ -1363,20 +1363,51 @@ class PwTabsComponent extends AppBaseComponent {
|
|
|
1363
1363
|
if (this.withSubscription) {
|
|
1364
1364
|
this.getUserSubscription().subscribe((subscription) => {
|
|
1365
1365
|
this.items.forEach(item => {
|
|
1366
|
-
// prepends the subscription slug to the route
|
|
1367
|
-
item.routerLink
|
|
1366
|
+
// prepends the subscription slug to the route while keeping routerLink as an array
|
|
1367
|
+
if (Array.isArray(item.routerLink) && item.routerLink.length > 0) {
|
|
1368
|
+
const originalRoute = item.routerLink[0];
|
|
1369
|
+
item.routerLink = [`/${subscription?.slug}${originalRoute}`];
|
|
1370
|
+
}
|
|
1368
1371
|
item.visible = item?.state
|
|
1369
1372
|
? this.permissionService.evaluatePermissions(item.state['permission'], PermissionService.selectedProduct?.feature_key, PermissionService.selectedProduct?.permission_key)
|
|
1370
1373
|
: item.visible;
|
|
1371
1374
|
});
|
|
1375
|
+
this.updateActiveTab();
|
|
1372
1376
|
});
|
|
1373
1377
|
}
|
|
1378
|
+
else {
|
|
1379
|
+
// For non-subscription tabs, update active tab after view init
|
|
1380
|
+
setTimeout(() => this.updateActiveTab(), 0);
|
|
1381
|
+
}
|
|
1374
1382
|
this.routeEventSubscription = this.router.events.subscribe(e => {
|
|
1375
1383
|
if (e instanceof NavigationEnd) {
|
|
1376
|
-
this.
|
|
1384
|
+
this.updateActiveTab();
|
|
1377
1385
|
}
|
|
1378
1386
|
});
|
|
1379
1387
|
}
|
|
1388
|
+
updateActiveTab() {
|
|
1389
|
+
if (!this.tabInstance || !this.items.length) {
|
|
1390
|
+
return;
|
|
1391
|
+
}
|
|
1392
|
+
const currentUrl = this.router.url.split('?')[0];
|
|
1393
|
+
const matchedItem = this.items.find(item => {
|
|
1394
|
+
if (!item.routerLink || !item.visible) {
|
|
1395
|
+
return false;
|
|
1396
|
+
}
|
|
1397
|
+
const routePath = Array.isArray(item.routerLink) ? item.routerLink[0] : item.routerLink;
|
|
1398
|
+
return routePath === currentUrl;
|
|
1399
|
+
});
|
|
1400
|
+
if (matchedItem) {
|
|
1401
|
+
// Clear previous activeItem first to ensure only one tab is active
|
|
1402
|
+
this.tabInstance.activeItem = null;
|
|
1403
|
+
// Then set the new activeItem
|
|
1404
|
+
this.tabInstance.activeItem = matchedItem;
|
|
1405
|
+
}
|
|
1406
|
+
else {
|
|
1407
|
+
// Clear activeItem if no match found
|
|
1408
|
+
this.tabInstance.activeItem = null;
|
|
1409
|
+
}
|
|
1410
|
+
}
|
|
1380
1411
|
ngOnDestroy() {
|
|
1381
1412
|
this.routeEventSubscription.unsubscribe();
|
|
1382
1413
|
}
|
|
@@ -1711,7 +1742,8 @@ class SharedComponentsModule {
|
|
|
1711
1742
|
ProgressSpinnerModule,
|
|
1712
1743
|
AutoCompleteModule,
|
|
1713
1744
|
ImageCropperModule,
|
|
1714
|
-
UiSwitchModule, i1$2.NgxDaterangepickerMd, PermissionTreeComponent,
|
|
1745
|
+
UiSwitchModule, i1$2.NgxDaterangepickerMd, PermissionTreeComponent,
|
|
1746
|
+
PrivacyAndTosComponent,
|
|
1715
1747
|
PrivacyPolicyComponent,
|
|
1716
1748
|
TermsConditionsComponent,
|
|
1717
1749
|
SplashComponent,
|
|
@@ -1784,14 +1816,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
1784
1816
|
CommonModule,
|
|
1785
1817
|
NgIf,
|
|
1786
1818
|
FieldErrorDisplayModule,
|
|
1787
|
-
ResourceSharedComponentsModule
|
|
1819
|
+
ResourceSharedComponentsModule
|
|
1788
1820
|
],
|
|
1789
1821
|
exports: [
|
|
1790
1822
|
PasswordValidationComponent,
|
|
1791
1823
|
PwTabsComponent,
|
|
1792
1824
|
DateRangePickerComponent,
|
|
1793
1825
|
allModules,
|
|
1794
|
-
PermissionTreeComponent,
|
|
1826
|
+
PermissionTreeComponent,
|
|
1827
|
+
PrivacyAndTosComponent,
|
|
1795
1828
|
PrivacyPolicyComponent,
|
|
1796
1829
|
TermsConditionsComponent,
|
|
1797
1830
|
SplashComponent,
|