@retalia/sidebar-navigation 13.4.0 → 16.2.12
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/{esm2020 → esm2022}/lib/data/support-routes.mjs +54 -54
- package/{esm2020 → esm2022}/lib/data/test-data.mjs +620 -620
- package/{esm2020 → esm2022}/lib/models/cookie-names.mjs +13 -13
- package/{esm2020 → esm2022}/lib/models/environment.mjs +1 -1
- package/{esm2020 → esm2022}/lib/models/http-response.mjs +1 -1
- package/{esm2020 → esm2022}/lib/models/module.mjs +1 -1
- package/esm2022/lib/navigation-lib.component.mjs +28 -0
- package/esm2022/lib/navigation-lib.module.mjs +47 -0
- package/{esm2020 → esm2022}/lib/navigation-lib.service.mjs +14 -14
- package/{esm2020 → esm2022}/lib/services/auth.service.mjs +43 -43
- package/{esm2020 → esm2022}/lib/services/cookie.service.mjs +34 -34
- package/{esm2020 → esm2022}/lib/services/http.service.mjs +18 -18
- package/{esm2020 → esm2022}/lib/services/module.service.mjs +133 -133
- package/{esm2020 → esm2022}/lib/services/sub-item.service.mjs +47 -47
- package/{esm2020 → esm2022}/lib/sidebar/shop-modal/shop-modal.component.mjs +40 -40
- package/{esm2020 → esm2022}/lib/sidebar/sidebar.component.mjs +182 -182
- package/esm2022/lib/sidebar/sub-item/sub-item.component.mjs +52 -0
- package/{esm2020 → esm2022}/lib/topbar/topbar.component.mjs +68 -68
- package/{esm2020 → esm2022}/public-api.mjs +11 -11
- package/{esm2020 → esm2022}/retalia-sidebar-navigation.mjs +4 -4
- package/fesm2022/retalia-sidebar-navigation.mjs +1355 -0
- package/{fesm2020 → fesm2022}/retalia-sidebar-navigation.mjs.map +1 -1
- package/{retalia-sidebar-navigation.d.ts → index.d.ts} +5 -5
- package/lib/data/support-routes.d.ts +2 -2
- package/lib/data/test-data.d.ts +2 -2
- package/lib/models/cookie-names.d.ts +12 -12
- package/lib/models/environment.d.ts +4 -4
- package/lib/models/http-response.d.ts +3 -3
- package/lib/models/module.d.ts +32 -32
- package/lib/navigation-lib.component.d.ts +12 -12
- package/lib/navigation-lib.module.d.ts +14 -14
- package/lib/navigation-lib.service.d.ts +6 -6
- package/lib/services/auth.service.d.ts +12 -12
- package/lib/services/cookie.service.d.ts +12 -12
- package/lib/services/http.service.d.ts +2 -2
- package/lib/services/module.service.d.ts +20 -20
- package/lib/services/sub-item.service.d.ts +12 -12
- package/lib/sidebar/shop-modal/shop-modal.component.d.ts +17 -17
- package/lib/sidebar/sidebar.component.d.ts +47 -47
- package/lib/sidebar/sub-item/sub-item.component.d.ts +16 -16
- package/lib/topbar/topbar.component.d.ts +20 -20
- package/package.json +13 -29
- package/public-api.d.ts +8 -8
- package/esm2020/lib/navigation-lib.component.mjs +0 -28
- package/esm2020/lib/navigation-lib.module.mjs +0 -50
- package/esm2020/lib/sidebar/sub-item/sub-item.component.mjs +0 -52
- package/fesm2015/retalia-sidebar-navigation.mjs +0 -1367
- package/fesm2015/retalia-sidebar-navigation.mjs.map +0 -1
- package/fesm2020/retalia-sidebar-navigation.mjs +0 -1358
|
@@ -1,133 +1,133 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { httpGet } from './http.service';
|
|
3
|
-
import { Subject } from 'rxjs';
|
|
4
|
-
import { testModuleDetails } from '../data/test-data';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export class ModuleService {
|
|
7
|
-
constructor() {
|
|
8
|
-
this.storedModuleFlags = [];
|
|
9
|
-
this.storedModuleFlagsChange = new Subject();
|
|
10
|
-
this.currentRouteName = new Subject();
|
|
11
|
-
this.storedModuleFlagsChange.subscribe((value) => {
|
|
12
|
-
this.storedModuleFlags = value;
|
|
13
|
-
});
|
|
14
|
-
}
|
|
15
|
-
async getUserModules(gatewayUrl, token) {
|
|
16
|
-
if (gatewayUrl === 'TEST') {
|
|
17
|
-
this.storedModuleFlagsChange.next(testModuleDetails.flags);
|
|
18
|
-
return Promise.resolve(testModuleDetails);
|
|
19
|
-
}
|
|
20
|
-
const requestUrl = gatewayUrl + '/Module';
|
|
21
|
-
const response = await httpGet(requestUrl, token);
|
|
22
|
-
this.storedModuleFlagsChange.next(response.parsedBody.flags);
|
|
23
|
-
return Promise.resolve(response.parsedBody);
|
|
24
|
-
}
|
|
25
|
-
setNavigationTitle(selectedItem) {
|
|
26
|
-
var pathArray = window.location.pathname.split('/');
|
|
27
|
-
let translatedModuleName = '';
|
|
28
|
-
let item = selectedItem;
|
|
29
|
-
if (pathArray.length > 1 && !item) {
|
|
30
|
-
let currentPath = window.location.pathname;
|
|
31
|
-
item = this.findNestedUrlMatch(this.modules, currentPath);
|
|
32
|
-
item
|
|
33
|
-
? (translatedModuleName = item.translatedName || item.name)
|
|
34
|
-
: (translatedModuleName = pathArray[pathArray.length - 1]);
|
|
35
|
-
}
|
|
36
|
-
else if (item) {
|
|
37
|
-
translatedModuleName = item.translatedName || item.name;
|
|
38
|
-
}
|
|
39
|
-
translatedModuleName === 'main' ? (translatedModuleName = '') : '';
|
|
40
|
-
this.currentRouteName.next(translatedModuleName);
|
|
41
|
-
if (item) {
|
|
42
|
-
this.setItemVisbility(item);
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
this.currentModule = this.modules.find((m) => m.url.toLowerCase().replace(/\//g, '') ===
|
|
46
|
-
pathArray[1].toLowerCase().replace(/\//g, ''));
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
findNestedUrlMatch(subItems, urlPath) {
|
|
50
|
-
let nameMatch;
|
|
51
|
-
subItems.forEach((i) => {
|
|
52
|
-
if (i.url &&
|
|
53
|
-
i.url.replace(/\//g, '') &&
|
|
54
|
-
i.url.toLowerCase().replace(/\//g, '') ===
|
|
55
|
-
urlPath.toLowerCase().replace(/\//g, '')) {
|
|
56
|
-
nameMatch = i;
|
|
57
|
-
i.active = true;
|
|
58
|
-
}
|
|
59
|
-
else {
|
|
60
|
-
i.active = false;
|
|
61
|
-
const childMatch = this.findNestedUrlMatch(i.children, urlPath);
|
|
62
|
-
if (childMatch) {
|
|
63
|
-
nameMatch = childMatch;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
});
|
|
67
|
-
return nameMatch;
|
|
68
|
-
}
|
|
69
|
-
setItemVisbility(item) {
|
|
70
|
-
let activeModule = this.modules.find((m) => m.authorizationId ===
|
|
71
|
-
(item.authorizationId || item.moduleAuthorizationId));
|
|
72
|
-
this.currentModule ? '' : (this.currentModule = activeModule);
|
|
73
|
-
activeModule.children.map((se) => {
|
|
74
|
-
se.visible = true;
|
|
75
|
-
if (item.name !== se.name) {
|
|
76
|
-
let isCurrent = se.children.some((sec) => sec.name === item.name);
|
|
77
|
-
se.children.map((sec) => {
|
|
78
|
-
sec.visible = isCurrent;
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
mapModuleItems(modules) {
|
|
84
|
-
modules.sort((a, b) => a.displayOrder - b.displayOrder || a.name.localeCompare(b.name)); // Alphabetically if modules share a displayOrder
|
|
85
|
-
const isSupportAdmin = this.storedModuleFlags.includes('SupportAdmin');
|
|
86
|
-
const isTenantAdmin = this.storedModuleFlags.includes('TenantAdmin');
|
|
87
|
-
let portalModule = modules.find((m) => m.authorizationId === 'portal');
|
|
88
|
-
isTenantAdmin ? '' : (modules = modules.filter((m) => m !== portalModule));
|
|
89
|
-
// modules = this.mapAdminItems(modules, isSupportAdmin); // Pending support for individual item flags
|
|
90
|
-
this.modules = modules.map((m) => {
|
|
91
|
-
if (m && m.sidebarEntries) {
|
|
92
|
-
m.children = JSON.parse(JSON.stringify(m.sidebarEntries));
|
|
93
|
-
m.sidebarEntries = [];
|
|
94
|
-
}
|
|
95
|
-
else {
|
|
96
|
-
m.children = [];
|
|
97
|
-
}
|
|
98
|
-
m.visible = true;
|
|
99
|
-
m.sidebarEntries ? `` : (m.children = []);
|
|
100
|
-
m.url ? `` : (m.url = '/');
|
|
101
|
-
return m;
|
|
102
|
-
});
|
|
103
|
-
this.setNavigationTitle();
|
|
104
|
-
return this.modules;
|
|
105
|
-
}
|
|
106
|
-
mapAdminItems(modules, isSupportAdmin) {
|
|
107
|
-
modules.forEach((m) => {
|
|
108
|
-
if (!isSupportAdmin && m.isAdminOnly) {
|
|
109
|
-
modules = modules.filter((i) => i.name !== m.name);
|
|
110
|
-
}
|
|
111
|
-
if (m.children) {
|
|
112
|
-
m.children = this.mapAdminItems(m.children, isSupportAdmin);
|
|
113
|
-
}
|
|
114
|
-
});
|
|
115
|
-
return modules;
|
|
116
|
-
}
|
|
117
|
-
getCurrentModule(selectedItem) {
|
|
118
|
-
var moduleRoute = window.location.pathname.split('/')[1];
|
|
119
|
-
if (!moduleRoute)
|
|
120
|
-
return null;
|
|
121
|
-
this.setNavigationTitle(selectedItem);
|
|
122
|
-
return this.modules.filter(m => m.url.indexOf(moduleRoute) > 0)[0];
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
128
|
-
type: Injectable,
|
|
129
|
-
args: [{
|
|
130
|
-
providedIn: 'root',
|
|
131
|
-
}]
|
|
132
|
-
}], ctorParameters: function () { return []; } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"module.service.js","sourceRoot":"","sources":["../../../../../projects/sidebar-navigation/src/lib/services/module.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { ModuleItem, ModulesInfo, SidebarEntry } from '../models/module';\r\nimport { httpGet } from './http.service';\r\nimport { Subject } from 'rxjs';\r\nimport { testModuleDetails } from '../data/test-data';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class ModuleService {\r\n  storedModuleFlags: string[] = [];\r\n  storedModuleFlagsChange: Subject<string[]> = new Subject<string[]>();\r\n  currentRouteName: Subject<string> = new Subject<string>();\r\n  currentModule;\r\n  modules: ModuleItem[];\r\n\r\n  constructor() {\r\n    this.storedModuleFlagsChange.subscribe((value) => {\r\n      this.storedModuleFlags = value;\r\n    });\r\n  }\r\n\r\n  public async getUserModules(\r\n    gatewayUrl: string,\r\n    token: string\r\n  ): Promise<ModulesInfo> {\r\n    if (gatewayUrl === 'TEST') {\r\n      this.storedModuleFlagsChange.next(testModuleDetails.flags);\r\n      return Promise.resolve(testModuleDetails);\r\n    }\r\n\r\n    const requestUrl = gatewayUrl + '/Module';\r\n    const response = await httpGet<ModulesInfo>(requestUrl, token);\r\n    this.storedModuleFlagsChange.next(response.parsedBody.flags);\r\n    return Promise.resolve(response.parsedBody);\r\n  }\r\n\r\n  public setNavigationTitle(selectedItem?: ModuleItem | SidebarEntry) {\r\n    var pathArray = window.location.pathname.split('/');\r\n    let translatedModuleName = '';\r\n    let item = selectedItem;\r\n    if (pathArray.length > 1 && !item) {\r\n      let currentPath = window.location.pathname;\r\n      item = this.findNestedUrlMatch(this.modules, currentPath);\r\n      item\r\n        ? (translatedModuleName = item.translatedName || item.name)\r\n        : (translatedModuleName = pathArray[pathArray.length - 1]);\r\n    } else if (item) {\r\n      translatedModuleName = item.translatedName || item.name;\r\n    }\r\n    translatedModuleName === 'main' ? (translatedModuleName = '') : '';\r\n    this.currentRouteName.next(translatedModuleName);\r\n\r\n    if (item) {\r\n      this.setItemVisbility(item);\r\n    } else {\r\n      this.currentModule = this.modules.find(\r\n        (m) =>\r\n          m.url.toLowerCase().replace(/\\//g, '') ===\r\n          pathArray[1].toLowerCase().replace(/\\//g, '')\r\n      );\r\n    }\r\n  }\r\n\r\n  public findNestedUrlMatch(subItems, urlPath: string) {\r\n    let nameMatch;\r\n    subItems.forEach((i: ModuleItem | SidebarEntry) => {\r\n      if (\r\n        i.url &&\r\n        i.url.replace(/\\//g, '') &&\r\n        i.url.toLowerCase().replace(/\\//g, '') ===\r\n          urlPath.toLowerCase().replace(/\\//g, '')\r\n      ) {\r\n        nameMatch = i;\r\n        i.active = true;\r\n      } else {\r\n        i.active = false;\r\n        const childMatch = this.findNestedUrlMatch(i.children, urlPath);\r\n        if (childMatch) {\r\n          nameMatch = childMatch;\r\n        }\r\n      }\r\n    });\r\n\r\n    return nameMatch;\r\n  }\r\n\r\n  public setItemVisbility(item): void {\r\n    let activeModule: ModuleItem = this.modules.find(\r\n      (m: ModuleItem) =>\r\n        m.authorizationId ===\r\n        (item.authorizationId || item.moduleAuthorizationId)\r\n    );\r\n\r\n    this.currentModule ? '' : (this.currentModule = activeModule);\r\n    activeModule.children.map((se: SidebarEntry) => {\r\n      se.visible = true;\r\n      if (item.name !== se.name) {\r\n        let isCurrent = se.children.some((sec) => sec.name === item.name);\r\n        se.children.map((sec) => {\r\n          sec.visible = isCurrent;\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  public mapModuleItems(modules: ModuleItem[]): ModuleItem[] {\r\n    modules.sort(\r\n      (a, b) => a.displayOrder - b.displayOrder || a.name.localeCompare(b.name)\r\n    ); // Alphabetically if modules share a displayOrder\r\n    const isSupportAdmin = this.storedModuleFlags.includes('SupportAdmin');\r\n    const isTenantAdmin = this.storedModuleFlags.includes('TenantAdmin');\r\n    let portalModule = modules.find((m) => m.authorizationId === 'portal');\r\n    isTenantAdmin ? '' : (modules = modules.filter((m) => m !== portalModule));\r\n\r\n    // modules = this.mapAdminItems(modules, isSupportAdmin); // Pending support for individual item flags\r\n    this.modules = modules.map((m) => {\r\n      if (m && m.sidebarEntries) {\r\n        m.children = JSON.parse(JSON.stringify(m.sidebarEntries));\r\n        m.sidebarEntries = [];\r\n      } else {\r\n        m.children = [];\r\n      }\r\n      m.visible = true;\r\n      m.sidebarEntries ? `` : (m.children = []);\r\n      m.url ? `` : (m.url = '/');\r\n      return m;\r\n    });\r\n    this.setNavigationTitle();\r\n\r\n    return this.modules;\r\n  }\r\n\r\n  public mapAdminItems(modules, isSupportAdmin: boolean): ModuleItem[] {\r\n    modules.forEach((m) => {\r\n      if (!isSupportAdmin && m.isAdminOnly) {\r\n        modules = modules.filter((i) => i.name !== m.name);\r\n      }\r\n      if (m.children) {\r\n        m.children = this.mapAdminItems(m.children, isSupportAdmin);\r\n      }\r\n    });\r\n\r\n    return modules;\r\n  }\r\n\r\n  public getCurrentModule(selectedItem: ModuleItem | SidebarEntry): ModuleItem {\r\n    var moduleRoute = window.location.pathname.split('/')[1];\r\n    if (!moduleRoute) return null;\r\n    this.setNavigationTitle(selectedItem);\r\n    return this.modules.filter(m => m.url.indexOf(moduleRoute) > 0)[0];\r\n  }\r\n}\r\n"]}
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { httpGet } from './http.service';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
|
+
import { testModuleDetails } from '../data/test-data';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class ModuleService {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.storedModuleFlags = [];
|
|
9
|
+
this.storedModuleFlagsChange = new Subject();
|
|
10
|
+
this.currentRouteName = new Subject();
|
|
11
|
+
this.storedModuleFlagsChange.subscribe((value) => {
|
|
12
|
+
this.storedModuleFlags = value;
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
async getUserModules(gatewayUrl, token) {
|
|
16
|
+
if (gatewayUrl === 'TEST') {
|
|
17
|
+
this.storedModuleFlagsChange.next(testModuleDetails.flags);
|
|
18
|
+
return Promise.resolve(testModuleDetails);
|
|
19
|
+
}
|
|
20
|
+
const requestUrl = gatewayUrl + '/Module';
|
|
21
|
+
const response = await httpGet(requestUrl, token);
|
|
22
|
+
this.storedModuleFlagsChange.next(response.parsedBody.flags);
|
|
23
|
+
return Promise.resolve(response.parsedBody);
|
|
24
|
+
}
|
|
25
|
+
setNavigationTitle(selectedItem) {
|
|
26
|
+
var pathArray = window.location.pathname.split('/');
|
|
27
|
+
let translatedModuleName = '';
|
|
28
|
+
let item = selectedItem;
|
|
29
|
+
if (pathArray.length > 1 && !item) {
|
|
30
|
+
let currentPath = window.location.pathname;
|
|
31
|
+
item = this.findNestedUrlMatch(this.modules, currentPath);
|
|
32
|
+
item
|
|
33
|
+
? (translatedModuleName = item.translatedName || item.name)
|
|
34
|
+
: (translatedModuleName = pathArray[pathArray.length - 1]);
|
|
35
|
+
}
|
|
36
|
+
else if (item) {
|
|
37
|
+
translatedModuleName = item.translatedName || item.name;
|
|
38
|
+
}
|
|
39
|
+
translatedModuleName === 'main' ? (translatedModuleName = '') : '';
|
|
40
|
+
this.currentRouteName.next(translatedModuleName);
|
|
41
|
+
if (item) {
|
|
42
|
+
this.setItemVisbility(item);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.currentModule = this.modules.find((m) => m.url.toLowerCase().replace(/\//g, '') ===
|
|
46
|
+
pathArray[1].toLowerCase().replace(/\//g, ''));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
findNestedUrlMatch(subItems, urlPath) {
|
|
50
|
+
let nameMatch;
|
|
51
|
+
subItems.forEach((i) => {
|
|
52
|
+
if (i.url &&
|
|
53
|
+
i.url.replace(/\//g, '') &&
|
|
54
|
+
i.url.toLowerCase().replace(/\//g, '') ===
|
|
55
|
+
urlPath.toLowerCase().replace(/\//g, '')) {
|
|
56
|
+
nameMatch = i;
|
|
57
|
+
i.active = true;
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
i.active = false;
|
|
61
|
+
const childMatch = this.findNestedUrlMatch(i.children, urlPath);
|
|
62
|
+
if (childMatch) {
|
|
63
|
+
nameMatch = childMatch;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
return nameMatch;
|
|
68
|
+
}
|
|
69
|
+
setItemVisbility(item) {
|
|
70
|
+
let activeModule = this.modules.find((m) => m.authorizationId ===
|
|
71
|
+
(item.authorizationId || item.moduleAuthorizationId));
|
|
72
|
+
this.currentModule ? '' : (this.currentModule = activeModule);
|
|
73
|
+
activeModule.children.map((se) => {
|
|
74
|
+
se.visible = true;
|
|
75
|
+
if (item.name !== se.name) {
|
|
76
|
+
let isCurrent = se.children.some((sec) => sec.name === item.name);
|
|
77
|
+
se.children.map((sec) => {
|
|
78
|
+
sec.visible = isCurrent;
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
mapModuleItems(modules) {
|
|
84
|
+
modules.sort((a, b) => a.displayOrder - b.displayOrder || a.name.localeCompare(b.name)); // Alphabetically if modules share a displayOrder
|
|
85
|
+
const isSupportAdmin = this.storedModuleFlags.includes('SupportAdmin');
|
|
86
|
+
const isTenantAdmin = this.storedModuleFlags.includes('TenantAdmin');
|
|
87
|
+
let portalModule = modules.find((m) => m.authorizationId === 'portal');
|
|
88
|
+
isTenantAdmin ? '' : (modules = modules.filter((m) => m !== portalModule));
|
|
89
|
+
// modules = this.mapAdminItems(modules, isSupportAdmin); // Pending support for individual item flags
|
|
90
|
+
this.modules = modules.map((m) => {
|
|
91
|
+
if (m && m.sidebarEntries) {
|
|
92
|
+
m.children = JSON.parse(JSON.stringify(m.sidebarEntries));
|
|
93
|
+
m.sidebarEntries = [];
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
m.children = [];
|
|
97
|
+
}
|
|
98
|
+
m.visible = true;
|
|
99
|
+
m.sidebarEntries ? `` : (m.children = []);
|
|
100
|
+
m.url ? `` : (m.url = '/');
|
|
101
|
+
return m;
|
|
102
|
+
});
|
|
103
|
+
this.setNavigationTitle();
|
|
104
|
+
return this.modules;
|
|
105
|
+
}
|
|
106
|
+
mapAdminItems(modules, isSupportAdmin) {
|
|
107
|
+
modules.forEach((m) => {
|
|
108
|
+
if (!isSupportAdmin && m.isAdminOnly) {
|
|
109
|
+
modules = modules.filter((i) => i.name !== m.name);
|
|
110
|
+
}
|
|
111
|
+
if (m.children) {
|
|
112
|
+
m.children = this.mapAdminItems(m.children, isSupportAdmin);
|
|
113
|
+
}
|
|
114
|
+
});
|
|
115
|
+
return modules;
|
|
116
|
+
}
|
|
117
|
+
getCurrentModule(selectedItem) {
|
|
118
|
+
var moduleRoute = window.location.pathname.split('/')[1];
|
|
119
|
+
if (!moduleRoute)
|
|
120
|
+
return null;
|
|
121
|
+
this.setNavigationTitle(selectedItem);
|
|
122
|
+
return this.modules.filter(m => m.url.indexOf(moduleRoute) > 0)[0];
|
|
123
|
+
}
|
|
124
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ModuleService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
125
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ModuleService, providedIn: 'root' }); }
|
|
126
|
+
}
|
|
127
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ModuleService, decorators: [{
|
|
128
|
+
type: Injectable,
|
|
129
|
+
args: [{
|
|
130
|
+
providedIn: 'root',
|
|
131
|
+
}]
|
|
132
|
+
}], ctorParameters: function () { return []; } });
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"module.service.js","sourceRoot":"","sources":["../../../../../projects/sidebar-navigation/src/lib/services/module.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { ModuleItem, ModulesInfo, SidebarEntry } from '../models/module';\r\nimport { httpGet } from './http.service';\r\nimport { Subject } from 'rxjs';\r\nimport { testModuleDetails } from '../data/test-data';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class ModuleService {\r\n  storedModuleFlags: string[] = [];\r\n  storedModuleFlagsChange: Subject<string[]> = new Subject<string[]>();\r\n  currentRouteName: Subject<string> = new Subject<string>();\r\n  currentModule;\r\n  modules: ModuleItem[];\r\n\r\n  constructor() {\r\n    this.storedModuleFlagsChange.subscribe((value) => {\r\n      this.storedModuleFlags = value;\r\n    });\r\n  }\r\n\r\n  public async getUserModules(\r\n    gatewayUrl: string,\r\n    token: string\r\n  ): Promise<ModulesInfo> {\r\n    if (gatewayUrl === 'TEST') {\r\n      this.storedModuleFlagsChange.next(testModuleDetails.flags);\r\n      return Promise.resolve(testModuleDetails);\r\n    }\r\n\r\n    const requestUrl = gatewayUrl + '/Module';\r\n    const response = await httpGet<ModulesInfo>(requestUrl, token);\r\n    this.storedModuleFlagsChange.next(response.parsedBody.flags);\r\n    return Promise.resolve(response.parsedBody);\r\n  }\r\n\r\n  public setNavigationTitle(selectedItem?: ModuleItem | SidebarEntry) {\r\n    var pathArray = window.location.pathname.split('/');\r\n    let translatedModuleName = '';\r\n    let item = selectedItem;\r\n    if (pathArray.length > 1 && !item) {\r\n      let currentPath = window.location.pathname;\r\n      item = this.findNestedUrlMatch(this.modules, currentPath);\r\n      item\r\n        ? (translatedModuleName = item.translatedName || item.name)\r\n        : (translatedModuleName = pathArray[pathArray.length - 1]);\r\n    } else if (item) {\r\n      translatedModuleName = item.translatedName || item.name;\r\n    }\r\n    translatedModuleName === 'main' ? (translatedModuleName = '') : '';\r\n    this.currentRouteName.next(translatedModuleName);\r\n\r\n    if (item) {\r\n      this.setItemVisbility(item);\r\n    } else {\r\n      this.currentModule = this.modules.find(\r\n        (m) =>\r\n          m.url.toLowerCase().replace(/\\//g, '') ===\r\n          pathArray[1].toLowerCase().replace(/\\//g, '')\r\n      );\r\n    }\r\n  }\r\n\r\n  public findNestedUrlMatch(subItems, urlPath: string) {\r\n    let nameMatch;\r\n    subItems.forEach((i: ModuleItem | SidebarEntry) => {\r\n      if (\r\n        i.url &&\r\n        i.url.replace(/\\//g, '') &&\r\n        i.url.toLowerCase().replace(/\\//g, '') ===\r\n          urlPath.toLowerCase().replace(/\\//g, '')\r\n      ) {\r\n        nameMatch = i;\r\n        i.active = true;\r\n      } else {\r\n        i.active = false;\r\n        const childMatch = this.findNestedUrlMatch(i.children, urlPath);\r\n        if (childMatch) {\r\n          nameMatch = childMatch;\r\n        }\r\n      }\r\n    });\r\n\r\n    return nameMatch;\r\n  }\r\n\r\n  public setItemVisbility(item): void {\r\n    let activeModule: ModuleItem = this.modules.find(\r\n      (m: ModuleItem) =>\r\n        m.authorizationId ===\r\n        (item.authorizationId || item.moduleAuthorizationId)\r\n    );\r\n\r\n    this.currentModule ? '' : (this.currentModule = activeModule);\r\n    activeModule.children.map((se: SidebarEntry) => {\r\n      se.visible = true;\r\n      if (item.name !== se.name) {\r\n        let isCurrent = se.children.some((sec) => sec.name === item.name);\r\n        se.children.map((sec) => {\r\n          sec.visible = isCurrent;\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  public mapModuleItems(modules: ModuleItem[]): ModuleItem[] {\r\n    modules.sort(\r\n      (a, b) => a.displayOrder - b.displayOrder || a.name.localeCompare(b.name)\r\n    ); // Alphabetically if modules share a displayOrder\r\n    const isSupportAdmin = this.storedModuleFlags.includes('SupportAdmin');\r\n    const isTenantAdmin = this.storedModuleFlags.includes('TenantAdmin');\r\n    let portalModule = modules.find((m) => m.authorizationId === 'portal');\r\n    isTenantAdmin ? '' : (modules = modules.filter((m) => m !== portalModule));\r\n\r\n    // modules = this.mapAdminItems(modules, isSupportAdmin); // Pending support for individual item flags\r\n    this.modules = modules.map((m) => {\r\n      if (m && m.sidebarEntries) {\r\n        m.children = JSON.parse(JSON.stringify(m.sidebarEntries));\r\n        m.sidebarEntries = [];\r\n      } else {\r\n        m.children = [];\r\n      }\r\n      m.visible = true;\r\n      m.sidebarEntries ? `` : (m.children = []);\r\n      m.url ? `` : (m.url = '/');\r\n      return m;\r\n    });\r\n    this.setNavigationTitle();\r\n\r\n    return this.modules;\r\n  }\r\n\r\n  public mapAdminItems(modules, isSupportAdmin: boolean): ModuleItem[] {\r\n    modules.forEach((m) => {\r\n      if (!isSupportAdmin && m.isAdminOnly) {\r\n        modules = modules.filter((i) => i.name !== m.name);\r\n      }\r\n      if (m.children) {\r\n        m.children = this.mapAdminItems(m.children, isSupportAdmin);\r\n      }\r\n    });\r\n\r\n    return modules;\r\n  }\r\n\r\n  public getCurrentModule(selectedItem: ModuleItem | SidebarEntry): ModuleItem {\r\n    var moduleRoute = window.location.pathname.split('/')[1];\r\n    if (!moduleRoute) return null;\r\n    this.setNavigationTitle(selectedItem);\r\n    return this.modules.filter(m => m.url.indexOf(moduleRoute) > 0)[0];\r\n  }\r\n}\r\n"]}
|
|
@@ -1,47 +1,47 @@
|
|
|
1
|
-
import { EventEmitter, Injectable } from '@angular/core';
|
|
2
|
-
import { getDomain } from 'tldjs';
|
|
3
|
-
import { set as setCookie } from 'es-cookie';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export class SubItemService {
|
|
6
|
-
constructor() {
|
|
7
|
-
this.subItemClickEvent = new EventEmitter();
|
|
8
|
-
this._storage = window.localStorage;
|
|
9
|
-
}
|
|
10
|
-
saveItemInfo(selectedModule, shopId) {
|
|
11
|
-
let moduleKey = `context${selectedModule.relationName}Id`;
|
|
12
|
-
let entity = selectedModule;
|
|
13
|
-
// The POS module is a special case and we dont want to change the shopId context when
|
|
14
|
-
// changing for the other modules. We only change the shopId context for the POS when
|
|
15
|
-
// explicitly clicking a new shopId on the POS module.
|
|
16
|
-
// For legacy reasons the POS uses the generic key 'shopId' and modules use 'contextShopId'.
|
|
17
|
-
if (selectedModule.authorizationId === 'pos') {
|
|
18
|
-
moduleKey = 'shopId';
|
|
19
|
-
entity = shopId;
|
|
20
|
-
}
|
|
21
|
-
if ((selectedModule.authorizationId !== 'pos' &&
|
|
22
|
-
selectedModule.entityAccess.length > 0) ||
|
|
23
|
-
selectedModule.name === 'orb') {
|
|
24
|
-
entity = shopId;
|
|
25
|
-
}
|
|
26
|
-
let tld = getDomain(window.location.href);
|
|
27
|
-
tld = tld !== null ? `.${tld}` : '';
|
|
28
|
-
// ? Sets the new data into storage, with a formatted domain
|
|
29
|
-
this._storage.setItem(moduleKey, entity.toString());
|
|
30
|
-
// ? TEMP: Sets the new cookie, with a formatted domain
|
|
31
|
-
setCookie(moduleKey, entity.toString(), {
|
|
32
|
-
path: '/',
|
|
33
|
-
domain: tld,
|
|
34
|
-
sameSite: 'none',
|
|
35
|
-
secure: true
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
subItemclicked(item) {
|
|
39
|
-
this.subItemClickEvent.emit(item);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
45
|
-
type: Injectable
|
|
46
|
-
}], ctorParameters: function () { return []; } });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { EventEmitter, Injectable } from '@angular/core';
|
|
2
|
+
import { getDomain } from 'tldjs';
|
|
3
|
+
import { set as setCookie } from 'es-cookie';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class SubItemService {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.subItemClickEvent = new EventEmitter();
|
|
8
|
+
this._storage = window.localStorage;
|
|
9
|
+
}
|
|
10
|
+
saveItemInfo(selectedModule, shopId) {
|
|
11
|
+
let moduleKey = `context${selectedModule.relationName}Id`;
|
|
12
|
+
let entity = selectedModule;
|
|
13
|
+
// The POS module is a special case and we dont want to change the shopId context when
|
|
14
|
+
// changing for the other modules. We only change the shopId context for the POS when
|
|
15
|
+
// explicitly clicking a new shopId on the POS module.
|
|
16
|
+
// For legacy reasons the POS uses the generic key 'shopId' and modules use 'contextShopId'.
|
|
17
|
+
if (selectedModule.authorizationId === 'pos') {
|
|
18
|
+
moduleKey = 'shopId';
|
|
19
|
+
entity = shopId;
|
|
20
|
+
}
|
|
21
|
+
if ((selectedModule.authorizationId !== 'pos' &&
|
|
22
|
+
selectedModule.entityAccess.length > 0) ||
|
|
23
|
+
selectedModule.name === 'orb') {
|
|
24
|
+
entity = shopId;
|
|
25
|
+
}
|
|
26
|
+
let tld = getDomain(window.location.href);
|
|
27
|
+
tld = tld !== null ? `.${tld}` : '';
|
|
28
|
+
// ? Sets the new data into storage, with a formatted domain
|
|
29
|
+
this._storage.setItem(moduleKey, entity.toString());
|
|
30
|
+
// ? TEMP: Sets the new cookie, with a formatted domain
|
|
31
|
+
setCookie(moduleKey, entity.toString(), {
|
|
32
|
+
path: '/',
|
|
33
|
+
domain: tld,
|
|
34
|
+
sameSite: 'none',
|
|
35
|
+
secure: true
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
subItemclicked(item) {
|
|
39
|
+
this.subItemClickEvent.emit(item);
|
|
40
|
+
}
|
|
41
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SubItemService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
42
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SubItemService }); }
|
|
43
|
+
}
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SubItemService, decorators: [{
|
|
45
|
+
type: Injectable
|
|
46
|
+
}], ctorParameters: function () { return []; } });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ViLWl0ZW0uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpZGViYXItbmF2aWdhdGlvbi9zcmMvbGliL3NlcnZpY2VzL3N1Yi1pdGVtLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUNsQyxPQUFPLEVBQUUsR0FBRyxJQUFJLFNBQVMsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7QUFHN0MsTUFBTSxPQUFPLGNBQWM7SUFJekI7UUFIQSxzQkFBaUIsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBSXJDLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQztJQUN0QyxDQUFDO0lBRU0sWUFBWSxDQUFDLGNBQTBCLEVBQUUsTUFBYztRQUM1RCxJQUFJLFNBQVMsR0FBRyxVQUFVLGNBQWMsQ0FBQyxZQUFZLElBQUksQ0FBQztRQUMxRCxJQUFJLE1BQU0sR0FBUSxjQUFjLENBQUM7UUFFakMsc0ZBQXNGO1FBQ3RGLHFGQUFxRjtRQUNyRixzREFBc0Q7UUFDdEQsNEZBQTRGO1FBQzVGLElBQUksY0FBYyxDQUFDLGVBQWUsS0FBSyxLQUFLLEVBQUU7WUFDNUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztZQUNyQixNQUFNLEdBQUcsTUFBTSxDQUFDO1NBQ2pCO1FBRUQsSUFDRSxDQUFDLGNBQWMsQ0FBQyxlQUFlLEtBQUssS0FBSztZQUN2QyxjQUFjLENBQUMsWUFBWSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7WUFDekMsY0FBYyxDQUFDLElBQUksS0FBSyxLQUFLLEVBQzdCO1lBQ0EsTUFBTSxHQUFHLE1BQU0sQ0FBQztTQUNqQjtRQUVELElBQUksR0FBRyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFDLEdBQUcsR0FBRyxHQUFHLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFFcEMsNERBQTREO1FBQzVELElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUVwRCx1REFBdUQ7UUFDdkQsU0FBUyxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsUUFBUSxFQUFFLEVBQUU7WUFDdEMsSUFBSSxFQUFFLEdBQUc7WUFDVCxNQUFNLEVBQUUsR0FBRztZQUNYLFFBQVEsRUFBRyxNQUFNO1lBQ2pCLE1BQU0sRUFBRyxJQUFJO1NBQ2QsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGNBQWMsQ0FBQyxJQUFJO1FBQ2pCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEMsQ0FBQzsrR0E5Q1UsY0FBYzttSEFBZCxjQUFjOzs0RkFBZCxjQUFjO2tCQUQxQixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXZlbnRFbWl0dGVyLCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1vZHVsZUl0ZW0gfSBmcm9tICcuLi9tb2RlbHMvbW9kdWxlJztcclxuaW1wb3J0IHsgZ2V0RG9tYWluIH0gZnJvbSAndGxkanMnO1xyXG5pbXBvcnQgeyBzZXQgYXMgc2V0Q29va2llIH0gZnJvbSAnZXMtY29va2llJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIFN1Ykl0ZW1TZXJ2aWNlIHtcclxuICBzdWJJdGVtQ2xpY2tFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBfc3RvcmFnZTogU3RvcmFnZTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7XHJcbiAgICB0aGlzLl9zdG9yYWdlID0gd2luZG93LmxvY2FsU3RvcmFnZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBzYXZlSXRlbUluZm8oc2VsZWN0ZWRNb2R1bGU6IE1vZHVsZUl0ZW0sIHNob3BJZDogbnVtYmVyKTogdm9pZCB7XHJcbiAgICBsZXQgbW9kdWxlS2V5ID0gYGNvbnRleHQke3NlbGVjdGVkTW9kdWxlLnJlbGF0aW9uTmFtZX1JZGA7XHJcbiAgICBsZXQgZW50aXR5OiBhbnkgPSBzZWxlY3RlZE1vZHVsZTtcclxuXHJcbiAgICAvLyBUaGUgUE9TIG1vZHVsZSBpcyBhIHNwZWNpYWwgY2FzZSBhbmQgd2UgZG9udCB3YW50IHRvIGNoYW5nZSB0aGUgc2hvcElkIGNvbnRleHQgd2hlblxyXG4gICAgLy8gY2hhbmdpbmcgZm9yIHRoZSBvdGhlciBtb2R1bGVzLiBXZSBvbmx5IGNoYW5nZSB0aGUgc2hvcElkIGNvbnRleHQgZm9yIHRoZSBQT1Mgd2hlblxyXG4gICAgLy8gZXhwbGljaXRseSBjbGlja2luZyBhIG5ldyBzaG9wSWQgb24gdGhlIFBPUyBtb2R1bGUuXHJcbiAgICAvLyBGb3IgbGVnYWN5IHJlYXNvbnMgdGhlIFBPUyB1c2VzIHRoZSBnZW5lcmljIGtleSAnc2hvcElkJyBhbmQgbW9kdWxlcyB1c2UgJ2NvbnRleHRTaG9wSWQnLlxyXG4gICAgaWYgKHNlbGVjdGVkTW9kdWxlLmF1dGhvcml6YXRpb25JZCA9PT0gJ3BvcycpIHtcclxuICAgICAgbW9kdWxlS2V5ID0gJ3Nob3BJZCc7XHJcbiAgICAgIGVudGl0eSA9IHNob3BJZDtcclxuICAgIH1cclxuXHJcbiAgICBpZiAoXHJcbiAgICAgIChzZWxlY3RlZE1vZHVsZS5hdXRob3JpemF0aW9uSWQgIT09ICdwb3MnICYmXHJcbiAgICAgICAgc2VsZWN0ZWRNb2R1bGUuZW50aXR5QWNjZXNzLmxlbmd0aCA+IDApIHx8XHJcbiAgICAgIHNlbGVjdGVkTW9kdWxlLm5hbWUgPT09ICdvcmInXHJcbiAgICApIHtcclxuICAgICAgZW50aXR5ID0gc2hvcElkO1xyXG4gICAgfVxyXG5cclxuICAgIGxldCB0bGQgPSBnZXREb21haW4od2luZG93LmxvY2F0aW9uLmhyZWYpO1xyXG4gICAgdGxkID0gdGxkICE9PSBudWxsID8gYC4ke3RsZH1gIDogJyc7XHJcblxyXG4gICAgLy8gPyBTZXRzIHRoZSBuZXcgZGF0YSBpbnRvIHN0b3JhZ2UsIHdpdGggYSBmb3JtYXR0ZWQgZG9tYWluXHJcbiAgICB0aGlzLl9zdG9yYWdlLnNldEl0ZW0obW9kdWxlS2V5LCBlbnRpdHkudG9TdHJpbmcoKSk7XHJcblxyXG4gICAgLy8gPyBURU1QOiBTZXRzIHRoZSBuZXcgY29va2llLCB3aXRoIGEgZm9ybWF0dGVkIGRvbWFpblxyXG4gICAgc2V0Q29va2llKG1vZHVsZUtleSwgZW50aXR5LnRvU3RyaW5nKCksIHtcclxuICAgICAgcGF0aDogJy8nLFxyXG4gICAgICBkb21haW46IHRsZCxcclxuICAgICAgc2FtZVNpdGUgOiAnbm9uZScsIFxyXG4gICAgICBzZWN1cmUgOiB0cnVlXHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHN1Ykl0ZW1jbGlja2VkKGl0ZW0pIHtcclxuICAgIHRoaXMuc3ViSXRlbUNsaWNrRXZlbnQuZW1pdChpdGVtKTtcclxuICB9XHJcbn1cclxuXHJcbi8vIFRoaXMgc2VydmljZSBleGlzdHMgdG8gYWxsb3cgdGhlIEV2ZW50RW1pdHRlciB0byBidWJibGUgdXAgZnJvbSB0aGUgcmVjdXJzaXZlIHN1Ykl0ZW0gY29tcG9uZW50IHRvIHRoZSBwYXJlbnQgc2lkZWJhciBjb21wb25lbnQuXHJcbiJdfQ==
|
|
@@ -1,40 +1,40 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "ngx-smart-modal";
|
|
4
|
-
import * as i2 from "@angular/common";
|
|
5
|
-
export class ShopModalComponent {
|
|
6
|
-
constructor(ngxSmartModalService) {
|
|
7
|
-
this.ngxSmartModalService = ngxSmartModalService;
|
|
8
|
-
this.availableShops = [];
|
|
9
|
-
this.copyAvailableShops = [];
|
|
10
|
-
this.selectedShop = new EventEmitter();
|
|
11
|
-
this.shopSearchValue = '';
|
|
12
|
-
this.shopSearchPlaceholder = 'Search for a Shop ...';
|
|
13
|
-
}
|
|
14
|
-
shopSelected(shop) {
|
|
15
|
-
this.selectedShop.emit(shop);
|
|
16
|
-
this.ngxSmartModalService.getModal('shopModal').close();
|
|
17
|
-
}
|
|
18
|
-
handleShopSearch(e) {
|
|
19
|
-
if (this.copyAvailableShops.length < 1) {
|
|
20
|
-
this.copyAvailableShops = [...this.availableShops];
|
|
21
|
-
}
|
|
22
|
-
this.shopSearchValue = e && e.target ? e.target.value : '';
|
|
23
|
-
this.availableShops = this.copyAvailableShops.filter((shop) => shop.description
|
|
24
|
-
.toLowerCase()
|
|
25
|
-
.includes(this.shopSearchValue.toLowerCase()));
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
31
|
-
type: Component,
|
|
32
|
-
args: [{ selector: 'shop-modal', template: "<ngx-smart-modal #shopModal identifier=\"shopModal\">\r\n <h1 class=\"shopSelect\">Shop Select</h1>\r\n <ng-container *ngIf=\"availableShops\">\r\n <ng-container *ngIf=\"availableShops.length > 8 || copyAvailableShops.length > 8\">\r\n <input class=\"shopSearchInput\" type=\"search\" autocomplete=\"off\" id=\"search\" [value]=\"shopSearchValue\"\r\n required=\"false\" [placeholder]=\"shopSearchPlaceholder\" (keyup)=\"handleShopSearch($event)\"\r\n (click)=\"handleShopSearch($event)\" />\r\n </ng-container>\r\n <div class=\"shopButtons\">\r\n <button class=\"shopButton\" *ngFor=\"let shop of availableShops\"\r\n [attr.data-testid]=\"'nav-shop' + shop.id\"\r\n (click)=\"shopSelected(shop)\">{{shop.description}}</button>\r\n </div>\r\n </ng-container>\r\n</ngx-smart-modal>", styles: ["@import\"https://fonts.googleapis.com/css2?family=Source+Sans+Pro:ital,wght@0,300;0,400;1,300;1,400;1,600&display=swap\"
|
|
33
|
-
}], ctorParameters: function () { return [{ type: i1.NgxSmartModalService }]; }, propDecorators: { availableShops: [{
|
|
34
|
-
type: Input
|
|
35
|
-
}], selectedShop: [{
|
|
36
|
-
type: Output
|
|
37
|
-
}], shopSearchValue: [{
|
|
38
|
-
type: Input
|
|
39
|
-
}] } });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "ngx-smart-modal";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
export class ShopModalComponent {
|
|
6
|
+
constructor(ngxSmartModalService) {
|
|
7
|
+
this.ngxSmartModalService = ngxSmartModalService;
|
|
8
|
+
this.availableShops = [];
|
|
9
|
+
this.copyAvailableShops = [];
|
|
10
|
+
this.selectedShop = new EventEmitter();
|
|
11
|
+
this.shopSearchValue = '';
|
|
12
|
+
this.shopSearchPlaceholder = 'Search for a Shop ...';
|
|
13
|
+
}
|
|
14
|
+
shopSelected(shop) {
|
|
15
|
+
this.selectedShop.emit(shop);
|
|
16
|
+
this.ngxSmartModalService.getModal('shopModal').close();
|
|
17
|
+
}
|
|
18
|
+
handleShopSearch(e) {
|
|
19
|
+
if (this.copyAvailableShops.length < 1) {
|
|
20
|
+
this.copyAvailableShops = [...this.availableShops];
|
|
21
|
+
}
|
|
22
|
+
this.shopSearchValue = e && e.target ? e.target.value : '';
|
|
23
|
+
this.availableShops = this.copyAvailableShops.filter((shop) => shop.description
|
|
24
|
+
.toLowerCase()
|
|
25
|
+
.includes(this.shopSearchValue.toLowerCase()));
|
|
26
|
+
}
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ShopModalComponent, deps: [{ token: i1.NgxSmartModalService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
28
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ShopModalComponent, selector: "shop-modal", inputs: { availableShops: "availableShops", shopSearchValue: "shopSearchValue" }, outputs: { selectedShop: "selectedShop" }, ngImport: i0, template: "<ngx-smart-modal #shopModal identifier=\"shopModal\">\r\n <h1 class=\"shopSelect\">Shop Select</h1>\r\n <ng-container *ngIf=\"availableShops\">\r\n <ng-container *ngIf=\"availableShops.length > 8 || copyAvailableShops.length > 8\">\r\n <input class=\"shopSearchInput\" type=\"search\" autocomplete=\"off\" id=\"search\" [value]=\"shopSearchValue\"\r\n required=\"false\" [placeholder]=\"shopSearchPlaceholder\" (keyup)=\"handleShopSearch($event)\"\r\n (click)=\"handleShopSearch($event)\" />\r\n </ng-container>\r\n <div class=\"shopButtons\">\r\n <button class=\"shopButton\" *ngFor=\"let shop of availableShops\"\r\n [attr.data-testid]=\"'nav-shop' + shop.id\"\r\n (click)=\"shopSelected(shop)\">{{shop.description}}</button>\r\n </div>\r\n </ng-container>\r\n</ngx-smart-modal>", styles: ["@import\"https://fonts.googleapis.com/css2?family=Source+Sans+Pro:ital,wght@0,300;0,400;1,300;1,400;1,600&display=swap\";.imagine-body{background-color:#fafbfc}@font-face{font-family:Poppins;src:url(../assets/fonts/Poppins-Regular.ttf) format(\"truetype\");font-weight:400;font-style:normal}@font-face{font-family:Poppins;src:url(../assets/fonts/Poppins-Bold.ttf) format(\"truetype\");font-weight:700;font-style:normal}@font-face{font-family:Poppins;src:url(../assets/fonts/Poppins-Italic.ttf) format(\"truetype\");font-weight:400;font-style:italic}@font-face{font-family:Poppins;src:url(../assets/fonts/Poppins-SemiBold.ttf) format(\"truetype\");font-weight:600;font-style:normal}#shopModal{direction:ltr}.shopButtons{display:block;padding:10px 0;margin:auto;width:100%;text-align:center}.shopButton{cursor:pointer;min-width:90px;border-radius:5px;border:none;outline:none;padding:5px 10px}.shopButton+.shopButton{margin-left:10px;margin-bottom:10px}.shopSearchInput{display:block;direction:ltr;width:90%;height:inherit;margin:auto}input:invalid{box-shadow:none}.shopSelect{font-size:18px;font-family:Poppins,sans-serif;text-align:center}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i1.NgxSmartModalComponent, selector: "ngx-smart-modal", inputs: ["closable", "escapable", "dismissable", "identifier", "customClass", "visible", "backdrop", "force", "hideDelay", "autostart", "target", "ariaLabel", "ariaLabelledBy", "ariaDescribedBy", "refocus"], outputs: ["visibleChange", "onClose", "onCloseFinished", "onDismiss", "onDismissFinished", "onAnyCloseEvent", "onAnyCloseEventFinished", "onOpen", "onOpenFinished", "onEscape", "onDataAdded", "onDataRemoved"] }] }); }
|
|
29
|
+
}
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ShopModalComponent, decorators: [{
|
|
31
|
+
type: Component,
|
|
32
|
+
args: [{ selector: 'shop-modal', template: "<ngx-smart-modal #shopModal identifier=\"shopModal\">\r\n <h1 class=\"shopSelect\">Shop Select</h1>\r\n <ng-container *ngIf=\"availableShops\">\r\n <ng-container *ngIf=\"availableShops.length > 8 || copyAvailableShops.length > 8\">\r\n <input class=\"shopSearchInput\" type=\"search\" autocomplete=\"off\" id=\"search\" [value]=\"shopSearchValue\"\r\n required=\"false\" [placeholder]=\"shopSearchPlaceholder\" (keyup)=\"handleShopSearch($event)\"\r\n (click)=\"handleShopSearch($event)\" />\r\n </ng-container>\r\n <div class=\"shopButtons\">\r\n <button class=\"shopButton\" *ngFor=\"let shop of availableShops\"\r\n [attr.data-testid]=\"'nav-shop' + shop.id\"\r\n (click)=\"shopSelected(shop)\">{{shop.description}}</button>\r\n </div>\r\n </ng-container>\r\n</ngx-smart-modal>", styles: ["@import\"https://fonts.googleapis.com/css2?family=Source+Sans+Pro:ital,wght@0,300;0,400;1,300;1,400;1,600&display=swap\";.imagine-body{background-color:#fafbfc}@font-face{font-family:Poppins;src:url(../assets/fonts/Poppins-Regular.ttf) format(\"truetype\");font-weight:400;font-style:normal}@font-face{font-family:Poppins;src:url(../assets/fonts/Poppins-Bold.ttf) format(\"truetype\");font-weight:700;font-style:normal}@font-face{font-family:Poppins;src:url(../assets/fonts/Poppins-Italic.ttf) format(\"truetype\");font-weight:400;font-style:italic}@font-face{font-family:Poppins;src:url(../assets/fonts/Poppins-SemiBold.ttf) format(\"truetype\");font-weight:600;font-style:normal}#shopModal{direction:ltr}.shopButtons{display:block;padding:10px 0;margin:auto;width:100%;text-align:center}.shopButton{cursor:pointer;min-width:90px;border-radius:5px;border:none;outline:none;padding:5px 10px}.shopButton+.shopButton{margin-left:10px;margin-bottom:10px}.shopSearchInput{display:block;direction:ltr;width:90%;height:inherit;margin:auto}input:invalid{box-shadow:none}.shopSelect{font-size:18px;font-family:Poppins,sans-serif;text-align:center}\n"] }]
|
|
33
|
+
}], ctorParameters: function () { return [{ type: i1.NgxSmartModalService }]; }, propDecorators: { availableShops: [{
|
|
34
|
+
type: Input
|
|
35
|
+
}], selectedShop: [{
|
|
36
|
+
type: Output
|
|
37
|
+
}], shopSearchValue: [{
|
|
38
|
+
type: Input
|
|
39
|
+
}] } });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hvcC1tb2RhbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaWRlYmFyLW5hdmlnYXRpb24vc3JjL2xpYi9zaWRlYmFyL3Nob3AtbW9kYWwvc2hvcC1tb2RhbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaWRlYmFyLW5hdmlnYXRpb24vc3JjL2xpYi9zaWRlYmFyL3Nob3AtbW9kYWwvc2hvcC1tb2RhbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBU3ZFLE1BQU0sT0FBTyxrQkFBa0I7SUFPN0IsWUFBbUIsb0JBQTBDO1FBQTFDLHlCQUFvQixHQUFwQixvQkFBb0IsQ0FBc0I7UUFOcEQsbUJBQWMsR0FBVyxFQUFFLENBQUM7UUFDckMsdUJBQWtCLEdBQVcsRUFBRSxDQUFDO1FBQ3RCLGlCQUFZLEdBQXVCLElBQUksWUFBWSxFQUFFLENBQUM7UUFDdkQsb0JBQWUsR0FBUSxFQUFFLENBQUM7UUFDbkMsMEJBQXFCLEdBQUcsdUJBQXVCLENBQUM7SUFFZ0IsQ0FBQztJQUVqRSxZQUFZLENBQUMsSUFBSTtRQUNmLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzdCLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDMUQsQ0FBQztJQUVELGdCQUFnQixDQUFDLENBQUM7UUFDaEIsSUFBSSxJQUFJLENBQUMsa0JBQWtCLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUN0QyxJQUFJLENBQUMsa0JBQWtCLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztTQUNwRDtRQUNELElBQUksQ0FBQyxlQUFlLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDM0QsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FDNUQsSUFBSSxDQUFDLFdBQVc7YUFDYixXQUFXLEVBQUU7YUFDYixRQUFRLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUNoRCxDQUFDO0lBQ0osQ0FBQzsrR0F4QlUsa0JBQWtCO21HQUFsQixrQkFBa0IsK0tDVC9CLHE0QkFja0I7OzRGRExMLGtCQUFrQjtrQkFMOUIsU0FBUzsrQkFDRSxZQUFZOzJHQUtiLGNBQWM7c0JBQXRCLEtBQUs7Z0JBRUksWUFBWTtzQkFBckIsTUFBTTtnQkFDRSxlQUFlO3NCQUF2QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTmd4U21hcnRNb2RhbFNlcnZpY2UgfSBmcm9tICduZ3gtc21hcnQtbW9kYWwnO1xyXG5pbXBvcnQgeyBTaG9wIH0gZnJvbSAnLi4vLi4vbW9kZWxzL21vZHVsZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3Nob3AtbW9kYWwnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9zaG9wLW1vZGFsLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zaG9wLW1vZGFsLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTaG9wTW9kYWxDb21wb25lbnQge1xyXG4gIEBJbnB1dCgpIGF2YWlsYWJsZVNob3BzOiBTaG9wW10gPSBbXTtcclxuICBjb3B5QXZhaWxhYmxlU2hvcHM6IFNob3BbXSA9IFtdO1xyXG4gIEBPdXRwdXQoKSBzZWxlY3RlZFNob3A6IEV2ZW50RW1pdHRlcjxTaG9wPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBASW5wdXQoKSBzaG9wU2VhcmNoVmFsdWU6IGFueSA9ICcnO1xyXG4gIHNob3BTZWFyY2hQbGFjZWhvbGRlciA9ICdTZWFyY2ggZm9yIGEgU2hvcCAuLi4nO1xyXG5cclxuICBjb25zdHJ1Y3RvcihwdWJsaWMgbmd4U21hcnRNb2RhbFNlcnZpY2U6IE5neFNtYXJ0TW9kYWxTZXJ2aWNlKSB7fVxyXG5cclxuICBzaG9wU2VsZWN0ZWQoc2hvcCk6IHZvaWQge1xyXG4gICAgdGhpcy5zZWxlY3RlZFNob3AuZW1pdChzaG9wKTtcclxuICAgIHRoaXMubmd4U21hcnRNb2RhbFNlcnZpY2UuZ2V0TW9kYWwoJ3Nob3BNb2RhbCcpLmNsb3NlKCk7XHJcbiAgfVxyXG5cclxuICBoYW5kbGVTaG9wU2VhcmNoKGUpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLmNvcHlBdmFpbGFibGVTaG9wcy5sZW5ndGggPCAxKSB7XHJcbiAgICAgIHRoaXMuY29weUF2YWlsYWJsZVNob3BzID0gWy4uLnRoaXMuYXZhaWxhYmxlU2hvcHNdO1xyXG4gICAgfVxyXG4gICAgdGhpcy5zaG9wU2VhcmNoVmFsdWUgPSBlICYmIGUudGFyZ2V0ID8gZS50YXJnZXQudmFsdWUgOiAnJztcclxuICAgIHRoaXMuYXZhaWxhYmxlU2hvcHMgPSB0aGlzLmNvcHlBdmFpbGFibGVTaG9wcy5maWx0ZXIoKHNob3ApID0+XHJcbiAgICAgIHNob3AuZGVzY3JpcHRpb25cclxuICAgICAgICAudG9Mb3dlckNhc2UoKVxyXG4gICAgICAgIC5pbmNsdWRlcyh0aGlzLnNob3BTZWFyY2hWYWx1ZS50b0xvd2VyQ2FzZSgpKVxyXG4gICAgKTtcclxuICB9XHJcbn1cclxuIiwiPG5neC1zbWFydC1tb2RhbCAjc2hvcE1vZGFsIGlkZW50aWZpZXI9XCJzaG9wTW9kYWxcIj5cclxuICAgIDxoMSBjbGFzcz1cInNob3BTZWxlY3RcIj5TaG9wIFNlbGVjdDwvaDE+XHJcbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiYXZhaWxhYmxlU2hvcHNcIj5cclxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiYXZhaWxhYmxlU2hvcHMubGVuZ3RoID4gOCB8fCBjb3B5QXZhaWxhYmxlU2hvcHMubGVuZ3RoID4gOFwiPlxyXG4gICAgICAgICAgICA8aW5wdXQgY2xhc3M9XCJzaG9wU2VhcmNoSW5wdXRcIiB0eXBlPVwic2VhcmNoXCIgYXV0b2NvbXBsZXRlPVwib2ZmXCIgaWQ9XCJzZWFyY2hcIiBbdmFsdWVdPVwic2hvcFNlYXJjaFZhbHVlXCJcclxuICAgICAgICAgICAgICAgIHJlcXVpcmVkPVwiZmFsc2VcIiBbcGxhY2Vob2xkZXJdPVwic2hvcFNlYXJjaFBsYWNlaG9sZGVyXCIgKGtleXVwKT1cImhhbmRsZVNob3BTZWFyY2goJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAgICAoY2xpY2spPVwiaGFuZGxlU2hvcFNlYXJjaCgkZXZlbnQpXCIgLz5cclxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwic2hvcEJ1dHRvbnNcIj5cclxuICAgICAgICAgICAgPGJ1dHRvbiBjbGFzcz1cInNob3BCdXR0b25cIiAqbmdGb3I9XCJsZXQgc2hvcCBvZiBhdmFpbGFibGVTaG9wc1wiXHJcbiAgICAgICAgICAgICAgICBbYXR0ci5kYXRhLXRlc3RpZF09XCInbmF2LXNob3AnICsgc2hvcC5pZFwiXHJcbiAgICAgICAgICAgICAgICAoY2xpY2spPVwic2hvcFNlbGVjdGVkKHNob3ApXCI+e3tzaG9wLmRlc2NyaXB0aW9ufX08L2J1dHRvbj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvbmctY29udGFpbmVyPlxyXG48L25neC1zbWFydC1tb2RhbD4iXX0=
|