namirasoft-account-react 1.4.406 → 1.4.410

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.
Files changed (46) hide show
  1. package/dist/App.js +5 -3
  2. package/dist/App.js.map +1 -1
  3. package/dist/NSACacheService.d.ts +18 -0
  4. package/dist/NSACacheService.js +64 -0
  5. package/dist/NSACacheService.js.map +1 -0
  6. package/dist/Router.js +2 -2
  7. package/dist/Router.js.map +1 -1
  8. package/dist/components/NSAMasterMenu.d.ts +29 -0
  9. package/dist/components/NSAMasterMenu.js +83 -0
  10. package/dist/components/NSAMasterMenu.js.map +1 -0
  11. package/dist/components/NSAMasterMenu.module.css +241 -0
  12. package/dist/components/NSAMasterMenuItem.d.ts +17 -0
  13. package/dist/components/NSAMasterMenuItem.js +111 -0
  14. package/dist/components/NSAMasterMenuItem.js.map +1 -0
  15. package/dist/components/NSAProductListDialog.d.ts +1 -1
  16. package/dist/components/NSAProductListDialog.js +4 -24
  17. package/dist/components/NSAProductListDialog.js.map +1 -1
  18. package/dist/layouts/NSALayout.d.ts +10 -7
  19. package/dist/layouts/NSALayout.js +89 -74
  20. package/dist/layouts/NSALayout.js.map +1 -1
  21. package/dist/layouts/NSASectionViewTabMore.js +3 -3
  22. package/dist/layouts/NSASectionViewTabMore.js.map +1 -1
  23. package/dist/layouts/NSASectionViewTabPage.d.ts +9 -1
  24. package/dist/layouts/NSASectionViewTabPage.js +19 -9
  25. package/dist/layouts/NSASectionViewTabPage.js.map +1 -1
  26. package/dist/pages/NSAConsentPage.js +2 -2
  27. package/dist/pages/NSAConsentPage.js.map +1 -1
  28. package/dist/pages/PaymentRequired.js +1 -1
  29. package/dist/pages/PaymentRequired.js.map +1 -1
  30. package/package.json +2 -2
  31. package/src/App.tsx +10 -4
  32. package/src/NSACacheService.ts +101 -0
  33. package/src/Router.tsx +2 -2
  34. package/src/components/NSAMasterMenu.module.css +241 -0
  35. package/src/components/NSAMasterMenu.tsx +170 -0
  36. package/src/components/NSAMasterMenuItem.tsx +251 -0
  37. package/src/components/NSAProductListDialog.tsx +74 -92
  38. package/src/layouts/NSALayout.tsx +734 -702
  39. package/src/layouts/NSASectionViewTabMore.tsx +3 -3
  40. package/src/layouts/NSASectionViewTabPage.tsx +44 -17
  41. package/src/pages/NSAConsentPage.tsx +2 -2
  42. package/src/pages/PaymentRequired.tsx +1 -1
  43. package/dist/ConsentCacheService.d.ts +0 -5
  44. package/dist/ConsentCacheService.js +0 -31
  45. package/dist/ConsentCacheService.js.map +0 -1
  46. package/src/ConsentCacheService.ts +0 -26
package/dist/App.js CHANGED
@@ -1,8 +1,10 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
1
+ import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
2
2
  import { NSALayout } from "./layouts/NSALayout";
3
- import { NSAHomePage } from "./main";
3
+ import { NSALoginPage } from "./pages/NSALoginPage";
4
4
  export function App(props) {
5
- return (_jsx(NSALayout, Object.assign({}, props, { children: _jsx(NSAHomePage, Object.assign({}, props, { product: { search: true } })) })));
5
+ if (!props.account)
6
+ return _jsx(NSALoginPage, { product_id: props.product_id });
7
+ return (_jsx(NSALayout, Object.assign({}, props, { header: { mega_menu: true }, children: _jsx(_Fragment, {}) })));
6
8
  }
7
9
  ;
8
10
  //# sourceMappingURL=App.js.map
package/dist/App.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"App.js","sourceRoot":"","sources":["../src/App.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAC;AAKrC,MAAM,UAAU,GAAG,CAAC,KAAe;IAE/B,OAAO,CACH,KAAC,SAAS,oBAAK,KAAK,cAChB,KAAC,WAAW,oBAAK,KAAK,IAAE,OAAO,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,IAC5C,CAChB,CAAC;AACN,CAAC;AAAA,CAAC"}
1
+ {"version":3,"file":"App.js","sourceRoot":"","sources":["../src/App.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAIpD,MAAM,UAAU,GAAG,CAAC,KAAe;IAE/B,IAAI,CAAC,KAAK,CAAC,OAAO;QACd,OAAO,KAAC,YAAY,IAAC,UAAU,EAAE,KAAK,CAAC,UAAU,GAAI,CAAA;IAEzD,OAAO,CACH,KAAC,SAAS,oBACF,KAAK,IACT,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,YAE3B,mBAAK,IACG,CACf,CAAC;AACN,CAAC;AAAA,CAAC"}
@@ -0,0 +1,18 @@
1
+ import { ProductFullRow } from "namirasoft-api-product";
2
+ import { CacheService } from "namirasoft-core";
3
+ import { ConsentRow, TokenManager } from "namirasoft-account";
4
+ import { FilterLinkFullRow } from "namirasoft-api-link";
5
+ import { NSNotifier } from "namirasoft-site-react";
6
+ export declare class NSACacheService {
7
+ static getProducts(notifier: NSNotifier): CacheService<{
8
+ rows: ProductFullRow[];
9
+ count: number;
10
+ }>;
11
+ static getConsent(manager: TokenManager, product_id: string, onError: (error: Error | string, timout?: number) => void): CacheService<ConsentRow | null>;
12
+ static getFilterLinks(scopes: string[]): CacheService<{
13
+ [scope: string]: FilterLinkFullRow[];
14
+ }>;
15
+ static getMasterMenuStatus(): CacheService<{
16
+ open: boolean;
17
+ }>;
18
+ }
@@ -0,0 +1,64 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import { NamirasoftAPIProductServer } from "namirasoft-api-product";
11
+ import { CacheService, EnvService, IStorageLocal, PackageService } from "namirasoft-core";
12
+ import { NamirasoftAccountServer } from "namirasoft-account";
13
+ import { NamirasoftAPILinkServer } from "namirasoft-api-link";
14
+ export class NSACacheService {
15
+ static getProducts(notifier) {
16
+ return new CacheService("ns-products", new IStorageLocal(), 7 * 24 * 60, () => __awaiter(this, void 0, void 0, function* () { return "1.0.0"; }), () => __awaiter(this, void 0, void 0, function* () {
17
+ var _a;
18
+ let REACT_APP_BASE_URL_API_PRODUCT = new EnvService("REACT_APP_BASE_URL_API_PRODUCT", true).getString();
19
+ let server = new NamirasoftAPIProductServer(REACT_APP_BASE_URL_API_PRODUCT, notifier.onError);
20
+ let ans = yield server.filter.ListProducts("Namirasoft Console", "Header", null, null, null, []);
21
+ if (PackageService.MainJson) {
22
+ let CurrentProjectName = (_a = PackageService.MainJson) === null || _a === void 0 ? void 0 : _a.title.replace("Console", "").trim();
23
+ ans.rows = ans.rows.filter(r => r.name !== CurrentProjectName);
24
+ ans.count = ans.rows.length;
25
+ }
26
+ return ans;
27
+ }));
28
+ }
29
+ static getConsent(manager, product_id, onError) {
30
+ let user_id = manager.getUserData(user => user.id, "");
31
+ let key = `ns-account-consent-user-${user_id}-product-${product_id}`;
32
+ return new CacheService(key, new IStorageLocal(), 7 * 24 * 60, () => __awaiter(this, void 0, void 0, function* () { return "1.0.0"; }), () => __awaiter(this, void 0, void 0, function* () {
33
+ let REACT_APP_BASE_URL_ACCOUNT = new EnvService("REACT_APP_BASE_URL_ACCOUNT", true).getString();
34
+ let server = new NamirasoftAccountServer(REACT_APP_BASE_URL_ACCOUNT, manager, onError);
35
+ try {
36
+ let ans = yield server.consent.GetByProduct(product_id);
37
+ return ans;
38
+ }
39
+ catch (error) {
40
+ return null;
41
+ }
42
+ }));
43
+ }
44
+ static getFilterLinks(scopes) {
45
+ return new CacheService(`ns-master-menu-filter-links`, new IStorageLocal(), 7 * 24 * 60, () => __awaiter(this, void 0, void 0, function* () { return "1.0.0"; }), () => __awaiter(this, void 0, void 0, function* () {
46
+ let REACT_APP_BASE_URL_API_LINK = new EnvService("REACT_APP_BASE_URL_API_LINK", true).getString();
47
+ let server = new NamirasoftAPILinkServer(REACT_APP_BASE_URL_API_LINK, console.error);
48
+ let entries = yield Promise.all(scopes.map((scope) => __awaiter(this, void 0, void 0, function* () {
49
+ try {
50
+ let response = yield server.filter.ListFilterLinks(scope, "Header", [], null, null, []);
51
+ return [scope, response.rows];
52
+ }
53
+ catch (error) {
54
+ return [scope, []];
55
+ }
56
+ })));
57
+ return Object.fromEntries(entries);
58
+ }));
59
+ }
60
+ static getMasterMenuStatus() {
61
+ return new CacheService(`ns-master-menu-status`, new IStorageLocal(), 30 * 24 * 60, () => __awaiter(this, void 0, void 0, function* () { return "1.0.0"; }), () => __awaiter(this, void 0, void 0, function* () { return ({ open: false }); }));
62
+ }
63
+ }
64
+ //# sourceMappingURL=NSACacheService.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NSACacheService.js","sourceRoot":"","sources":["../src/NSACacheService.ts"],"names":[],"mappings":"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"}
package/dist/Router.js CHANGED
@@ -9,9 +9,9 @@ import { ProductUUID } from 'namirasoft-api-product';
9
9
  export default function Router() {
10
10
  let [state, setState] = useState(Math.random());
11
11
  let navigate = useNavigate();
12
- let maker = new NSARouterMaker(ProductUUID.NAMIRASOFT_ACCESS, new IStorageSession(), () => { setState(state + Math.random()); }, {
12
+ let maker = new NSARouterMaker(ProductUUID.NAMIRASOFT_INFRA, new IStorageSession(), () => { setState(state + Math.random()); }, {
13
13
  onRenderOnLogin: (props) => {
14
- return (_jsxs(Routes, { children: [_jsx(Route, { path: "/:id", element: _jsx(App, Object.assign({}, props)) }), _jsx(Route, { path: "*", element: _jsx(App, Object.assign({}, props)) })] }));
14
+ return (_jsxs(Routes, { children: [_jsx(Route, { path: "/:id/view", element: _jsx(App, Object.assign({}, props)) }), _jsx(Route, { path: "*", element: _jsx(App, Object.assign({}, props)) })] }));
15
15
  },
16
16
  onRenderOnLogout: (_, __) => {
17
17
  return (_jsx(Routes, { children: _jsx(Route, { path: "*", element: _jsx(NSNotFoundPage, {}) }) }));
@@ -1 +1 @@
1
- {"version":3,"file":"Router.js","sourceRoot":"","sources":["../src/Router.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAC5B,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,MAAM,CAAC,OAAO,UAAU,MAAM;IAE1B,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAS,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAExD,IAAI,QAAQ,GAAG,WAAW,EAAE,CAAC;IAE7B,IAAI,KAAK,GAAG,IAAI,cAAc,CAAC,WAAW,CAAC,iBAAiB,EAAE,IAAI,eAAe,EAAE,EAAE,GAAG,EAAE,GAAG,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE;QAC7H,eAAe,EAAE,CAAC,KAA0B,EAAE,EAAE;YAE5C,OAAO,CACH,MAAC,MAAM,eACH,KAAC,KAAK,IAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAE,KAAC,GAAG,oBAAK,KAAK,EAAQ,GAAI,EACtD,KAAC,KAAK,IAAC,IAAI,EAAC,GAAG,EAAC,OAAO,EAAE,KAAC,GAAG,oBAAK,KAAK,EAAQ,GAAI,IAC9C,CACZ,CAAC;QACN,CAAC;QACD,gBAAgB,EAAE,CAAC,CAAsB,EAAE,EAAW,EAAE,EAAE;YAEtD,OAAO,CACH,KAAC,MAAM,cACH,KAAC,KAAK,IAAC,IAAI,EAAC,GAAG,EAAC,OAAO,EAAE,KAAC,cAAc,KAAkB,GAAI,GACzD,CACZ,CAAC;QACN,CAAC;QACD,iBAAiB,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE;YAE/B,OAAO,QAAQ,CAAC;QACpB,CAAC;QACD,WAAW,EAAE;YACT,YAAY,EAAE;gBACV,KAAK,EAAE,IAAI;gBACX,KAAK,EAAE,IAAI;aACd;SACJ;KACJ,EAAE,QAAQ,CAAC,CAAC;IACb,OAAO,KAAK,CAAC,QAAQ,EAAE,CAAC;AAC5B,CAAC"}
1
+ {"version":3,"file":"Router.js","sourceRoot":"","sources":["../src/Router.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAC5B,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,MAAM,CAAC,OAAO,UAAU,MAAM;IAE1B,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAS,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAExD,IAAI,QAAQ,GAAG,WAAW,EAAE,CAAC;IAE7B,IAAI,KAAK,GAAG,IAAI,cAAc,CAAC,WAAW,CAAC,gBAAgB,EAAE,IAAI,eAAe,EAAE,EAAE,GAAG,EAAE,GAAG,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE;QAC5H,eAAe,EAAE,CAAC,KAA0B,EAAE,EAAE;YAE5C,OAAO,CACH,MAAC,MAAM,eACH,KAAC,KAAK,IAAC,IAAI,EAAC,WAAW,EAAC,OAAO,EAAE,KAAC,GAAG,oBAAK,KAAK,EAAQ,GAAI,EAC3D,KAAC,KAAK,IAAC,IAAI,EAAC,GAAG,EAAC,OAAO,EAAE,KAAC,GAAG,oBAAK,KAAK,EAAQ,GAAI,IAC9C,CACZ,CAAC;QACN,CAAC;QACD,gBAAgB,EAAE,CAAC,CAAsB,EAAE,EAAW,EAAE,EAAE;YAEtD,OAAO,CACH,KAAC,MAAM,cACH,KAAC,KAAK,IAAC,IAAI,EAAC,GAAG,EAAC,OAAO,EAAE,KAAC,cAAc,KAAkB,GAAI,GACzD,CACZ,CAAC;QACN,CAAC;QACD,iBAAiB,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE;YAE/B,OAAO,QAAQ,CAAC;QACpB,CAAC;QACD,WAAW,EAAE;YACT,YAAY,EAAE;gBACV,KAAK,EAAE,IAAI;gBACX,KAAK,EAAE,IAAI;aACd;SACJ;KACJ,EAAE,QAAQ,CAAC,CAAC;IACb,OAAO,KAAK,CAAC,QAAQ,EAAE,CAAC;AAC5B,CAAC"}
@@ -0,0 +1,29 @@
1
+ import { FilterLinkFullRow } from "namirasoft-api-link";
2
+ import { ProductFullRow } from "namirasoft-api-product";
3
+ import { Component } from "react";
4
+ import { NSARouterMakerProps } from "../NSARouterMakerProps";
5
+ export interface NSAMasterMenuProps extends NSARouterMakerProps {
6
+ open: boolean;
7
+ setOpen: (open: boolean) => void;
8
+ }
9
+ export interface NSAMasterMenuState {
10
+ loading: boolean;
11
+ products?: ProductFullRow[];
12
+ filter_links?: {
13
+ [scope: string]: FilterLinkFullRow[];
14
+ };
15
+ show_footer: boolean;
16
+ search?: string;
17
+ }
18
+ declare class NSAMasterMenu extends Component<NSAMasterMenuProps, NSAMasterMenuState> {
19
+ private TimeoutSearch;
20
+ private MasterMenuAsideEl_Ref;
21
+ private MasterMenuEl_Ref;
22
+ constructor(props: NSAMasterMenuProps);
23
+ componentDidMount(): void;
24
+ componentDidUpdate(_: Readonly<NSAMasterMenuProps>, prev_state: Readonly<NSAMasterMenuState>): void;
25
+ load(): Promise<void>;
26
+ setSearch(search: string): void;
27
+ render(): import("react/jsx-runtime").JSX.Element;
28
+ }
29
+ export default NSAMasterMenu;
@@ -0,0 +1,83 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
11
+ import { SetTimeouService } from "namirasoft-core";
12
+ import { NSBoxSearch, NSLoading } from "namirasoft-site-react";
13
+ import { Component, createRef } from "react";
14
+ import { NSACacheService } from "../NSACacheService";
15
+ import Styles from "./NSAMasterMenu.module.css";
16
+ import NSAMasterMenuItem from "./NSAMasterMenuItem";
17
+ class NSAMasterMenu extends Component {
18
+ constructor(props) {
19
+ super(props);
20
+ this.MasterMenuAsideEl_Ref = createRef();
21
+ this.MasterMenuEl_Ref = createRef();
22
+ this.TimeoutSearch = new SetTimeouService();
23
+ this.state = {
24
+ loading: true,
25
+ show_footer: false,
26
+ };
27
+ this.load = this.load.bind(this);
28
+ }
29
+ componentDidMount() {
30
+ this.load();
31
+ }
32
+ componentDidUpdate(_, prev_state) {
33
+ if (this.state.search !== prev_state.search)
34
+ this.setState(() => ({ show_footer: false }));
35
+ }
36
+ load() {
37
+ return __awaiter(this, void 0, void 0, function* () {
38
+ try {
39
+ let product_list = yield NSACacheService.getProducts(this.props.notifier).get();
40
+ let scopes = product_list.rows.map((product) => `${product.name} Console`);
41
+ let filter_links = yield NSACacheService.getFilterLinks(scopes).get();
42
+ this.setState(() => ({
43
+ products: product_list.rows,
44
+ filter_links,
45
+ loading: false,
46
+ }));
47
+ }
48
+ catch (_a) {
49
+ this.setState(() => ({ loading: false }));
50
+ }
51
+ });
52
+ }
53
+ setSearch(search) {
54
+ this.TimeoutSearch.setTimeoutIfNotCalledAgain(() => this.setState(() => ({ search: search.length >= 3 ? search : undefined })), 1000);
55
+ }
56
+ render() {
57
+ var _a;
58
+ return (_jsx("aside", { ref: this.MasterMenuAsideEl_Ref, className: `${Styles.nsa_master_menu_aside} ${this.props.open ? Styles.open : ""}`, onClick: (event) => {
59
+ if (event.target === this.MasterMenuAsideEl_Ref.current)
60
+ this.props.setOpen(false);
61
+ }, children: _jsxs("div", { className: Styles.nsa_master_menu_wrapper, children: [_jsxs("div", { className: Styles.nsa_master_menu_header, children: [_jsx(NSBoxSearch, { title: "Search Product", required: false, hideHeader: true, placeholder: "Search", onChanged: (box) => { var _a; return this.setSearch((_a = box.getValue()) !== null && _a !== void 0 ? _a : ""); }, input: { classList: [Styles.nsa_master_menu_search_box] }, classList: [Styles.nsa_master_menu_search_wrapper] }), _jsx("button", { className: Styles.nsa_master_menu_header_btn, onClick: () => this.props.setOpen(!this.props.open), children: _jsx("img", { src: "https://static.namirasoft.com/image/concept/sidebar/blue.svg", alt: "collapse", width: 20, height: 20 }) })] }), _jsxs("div", { ref: this.MasterMenuEl_Ref, className: Styles.nsa_master_menu, onScroll: (event) => {
62
+ const element = event.target;
63
+ if (element.scrollTop && !this.state.show_footer)
64
+ this.setState(() => ({ show_footer: true }));
65
+ }, children: [!this.state.loading
66
+ ?
67
+ _jsx("ul", { className: Styles.nsa_master_menu_list, children: (_a = this.state.products) === null || _a === void 0 ? void 0 : _a.map(product => {
68
+ var _a, _b;
69
+ return (_jsx(NSAMasterMenuItem, Object.assign({}, this.props, { product: product, fls: (_b = (_a = this.state.filter_links) === null || _a === void 0 ? void 0 : _a[`${product.name} Console`]) !== null && _b !== void 0 ? _b : [], search: this.state.search, onClick: () => {
70
+ if (!this.props.open)
71
+ this.props.setOpen(true);
72
+ } }), product.id));
73
+ }) })
74
+ :
75
+ _jsx(NSLoading, { small: true, classList: [Styles.nsa_master_menu_loading] }), this.state.show_footer &&
76
+ _jsx("div", { className: Styles.nsa_master_menu_footer, children: _jsx("button", { className: Styles.nsa_master_menu_footer_btn, title: "Go Top", onClick: () => {
77
+ var _a;
78
+ (_a = this.MasterMenuEl_Ref.current) === null || _a === void 0 ? void 0 : _a.scroll({ top: 0 });
79
+ }, children: _jsx("img", { src: `https://static.namirasoft.com/image/concept/arrow/up/blue.svg`, alt: "angle", width: 12, height: 16 }) }) })] })] }) }));
80
+ }
81
+ }
82
+ export default NSAMasterMenu;
83
+ //# sourceMappingURL=NSAMasterMenu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NSAMasterMenu.js","sourceRoot":"","sources":["../../src/components/NSAMasterMenu.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,241 @@
1
+ .nsa_master_menu_aside {
2
+ position: fixed;
3
+ z-index: -1;
4
+ width: 100dvw;
5
+ height: 100dvh;
6
+ background-color: #00000080;
7
+ }
8
+
9
+ .nsa_master_menu_aside.open {
10
+ z-index: 999;
11
+ }
12
+
13
+ .nsa_master_menu_wrapper {
14
+ position: fixed;
15
+ width: 16rem;
16
+ height: 100dvh;
17
+ display: flex;
18
+ flex-direction: column;
19
+ background-color: #fbfafd;
20
+ overflow: hidden;
21
+ }
22
+
23
+ .nsa_master_menu_loading {
24
+ display: none;
25
+ }
26
+
27
+ .nsa_master_menu_aside.open .nsa_master_menu_loading {
28
+ display: flex;
29
+ }
30
+
31
+ /* header */
32
+
33
+ .nsa_master_menu_header {
34
+ padding: 1rem 0.5rem;
35
+ display: flex;
36
+ align-items: center;
37
+ gap: 0.5rem;
38
+ background-color: #e1e1e1;
39
+ }
40
+
41
+ .nsa_master_menu_search_box {
42
+ height: 2rem !important;
43
+ border: 1px solid #aeaeae !important;
44
+ background: url("https://static.namirasoft.com/image/concept/search/blue.svg") right 4px center / 16px no-repeat scroll white !important;
45
+ font-size: 0.875rem;
46
+ }
47
+
48
+ .nsa_master_menu_header_btn {
49
+ width: 2rem;
50
+ min-width: 2rem;
51
+ height: 2rem;
52
+ border: none;
53
+ border-radius: 0.25rem;
54
+ padding: 0;
55
+ display: flex;
56
+ align-items: center;
57
+ justify-content: center;
58
+ background-color: transparent;
59
+ }
60
+
61
+ .nsa_master_menu_header_btn:hover {
62
+ background-color: #d0d0d0;
63
+ }
64
+
65
+ /* menu */
66
+
67
+ .nsa_master_menu {
68
+ height: 100%;
69
+ padding: 0.5rem;
70
+ display: flex;
71
+ flex-direction: column;
72
+ gap: 0.5rem;
73
+ overflow: auto;
74
+ scroll-behavior: smooth;
75
+
76
+ &::-webkit-scrollbar {
77
+ width: 0.25rem;
78
+ }
79
+
80
+ &::-webkit-scrollbar-track {
81
+ background: rgba(0, 0, 0, 0.05);
82
+ border-radius: 0.25rem;
83
+ }
84
+
85
+ &::-webkit-scrollbar-thumb {
86
+ background: rgba(0, 0, 0, 0.3);
87
+ border-radius: 0.25rem;
88
+ }
89
+
90
+ &::-webkit-scrollbar-thumb:hover {
91
+ background: rgba(0, 0, 0, 0.45);
92
+ }
93
+ }
94
+
95
+ .nsa_master_menu_list {
96
+ list-style: none;
97
+ margin: 0;
98
+ padding: 0;
99
+ display: flex;
100
+ flex-direction: column;
101
+ gap: 0.25rem;
102
+ transition: height 0.25s ease;
103
+ }
104
+
105
+ .nsa_master_menu_list_item {
106
+ display: flex;
107
+ flex-direction: column;
108
+ gap: 0.25rem;
109
+ }
110
+
111
+ .nsa_master_menu_list_content {
112
+ width: 100%;
113
+ margin: 0;
114
+ border-radius: 0.25rem;
115
+ padding: 0.25rem 0.5rem 0.25rem 0.25rem;
116
+ display: flex;
117
+ align-items: center;
118
+ gap: 0.5rem;
119
+ cursor: pointer;
120
+ }
121
+
122
+ a.nsa_master_menu_list_content {
123
+ text-decoration: none;
124
+ }
125
+
126
+ .nsa_master_menu_list_content:hover {
127
+ background-color: #e1e1e1;
128
+ }
129
+
130
+ a.nsa_master_menu_list_content:hover {
131
+ text-decoration: underline;
132
+ }
133
+
134
+ .nsa_master_menu_list_content.back {
135
+ padding: 0 0 0.5rem 2.25rem;
136
+ }
137
+
138
+ .nsa_master_menu_list_text {
139
+ font-size: 0.875rem;
140
+ font-weight: 500;
141
+ line-height: 1rem;
142
+ color: #141b5c;
143
+ }
144
+
145
+ .nsa_master_menu_list_content.back .nsa_master_menu_list_text {
146
+ font-size: 1.125rem;
147
+ }
148
+
149
+ .nsa_master_menu_arrow {
150
+ margin-left: auto;
151
+ }
152
+
153
+ /* sub-menu */
154
+
155
+ .nsa_master_menu_list .nsa_master_menu_list {
156
+
157
+ .nsa_master_menu_list_content {
158
+ padding-left: 2.25rem;
159
+ }
160
+
161
+ .nsa_master_menu_list_text {
162
+ font-weight: 400;
163
+ }
164
+ }
165
+
166
+ /* footer */
167
+
168
+ .nsa_master_menu_footer {
169
+ border-top: 1px solid #e1e1e1;
170
+ margin-top: auto;
171
+ padding-top: 0.5rem;
172
+ }
173
+
174
+ .nsa_master_menu_footer_btn {
175
+ width: 100%;
176
+ border: none;
177
+ border-radius: 0.25rem;
178
+ padding: 0.25rem 0;
179
+ display: flex;
180
+ flex-direction: column;
181
+ align-items: center;
182
+ background-color: transparent;
183
+ }
184
+
185
+ .nsa_master_menu_footer_btn:hover {
186
+ background-color: #e1e1e1;
187
+ }
188
+
189
+ @media only screen and (min-width: 1200px) {
190
+ .nsa_master_menu_aside {
191
+ position: static;
192
+ z-index: 1;
193
+ width: 3rem;
194
+ min-width: 3rem;
195
+ display: flex;
196
+ }
197
+
198
+ .nsa_master_menu_wrapper {
199
+ width: 3rem;
200
+ }
201
+
202
+ .nsa_master_menu {
203
+ padding: 0.5rem 0.375rem;
204
+ }
205
+
206
+ .nsa_master_menu_list .nsa_master_menu_list {
207
+ display: none;
208
+ }
209
+
210
+ .nsa_master_menu_search_wrapper {
211
+ display: none;
212
+ }
213
+
214
+ .nsa_master_menu_list_text {
215
+ display: none;
216
+ }
217
+
218
+ .nsa_master_menu_arrow {
219
+ display: none;
220
+ }
221
+
222
+ .nsa_master_menu_aside.open {
223
+ width: 16rem;
224
+ min-width: 16rem;
225
+
226
+ .nsa_master_menu_wrapper {
227
+ width: 16rem;
228
+ }
229
+
230
+ .nsa_master_menu_list .nsa_master_menu_list,
231
+ .nsa_master_menu_search_wrapper,
232
+ .nsa_master_menu_list_text,
233
+ .nsa_master_menu_arrow {
234
+ display: flex;
235
+ }
236
+
237
+ .nsa_master_menu {
238
+ padding: 0.5rem;
239
+ }
240
+ }
241
+ }
@@ -0,0 +1,17 @@
1
+ import { FilterLinkFullRow } from "namirasoft-api-link";
2
+ import { ProductFullRow } from 'namirasoft-api-product';
3
+ import { NSARouterMakerProps } from '../NSARouterMakerProps';
4
+ export interface NSAMasterMenuItemProps extends NSARouterMakerProps {
5
+ product: ProductFullRow;
6
+ fls: FilterLinkFullRow[];
7
+ open: boolean;
8
+ search?: string;
9
+ onClick: () => void;
10
+ }
11
+ export interface NSAMasterMenuItemState {
12
+ chain: FilterLinkFullRow[];
13
+ active: boolean;
14
+ loading: boolean;
15
+ }
16
+ declare function NSAMasterMenuItem(props: NSAMasterMenuItemProps): import("react/jsx-runtime").JSX.Element;
17
+ export default NSAMasterMenuItem;
@@ -0,0 +1,111 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { NSLoading } from 'namirasoft-site-react';
3
+ import { useEffect, useMemo, useState } from 'react';
4
+ import Styles from "./NSAMasterMenu.module.css";
5
+ import { SearchOperation } from "namirasoft-core";
6
+ function NSAMasterMenuItem(props) {
7
+ var _a;
8
+ const [state, setState] = useState({
9
+ chain: [],
10
+ active: false,
11
+ loading: false
12
+ });
13
+ const getVisibleFLs = (fls) => {
14
+ var _a;
15
+ let is_logged_in = props.account.token_manager.exists();
16
+ let initial_filters = (_a = fls === null || fls === void 0 ? void 0 : fls.filter(filter => {
17
+ if (!filter.link)
18
+ return true;
19
+ return is_logged_in ? filter.link.private : filter.link.public;
20
+ })) !== null && _a !== void 0 ? _a : [];
21
+ return pruneOrphanFLs(initial_filters).sort((a, b) => a.order - b.order);
22
+ };
23
+ const pruneOrphanFLs = (fls) => {
24
+ let result = [...fls];
25
+ while (true) {
26
+ let previous_length = result.length;
27
+ let parent_ids = new Set(result.map(f => f.parent_id));
28
+ result = result.filter(filter => {
29
+ var _a;
30
+ if ((_a = filter.link) === null || _a === void 0 ? void 0 : _a.url)
31
+ return true;
32
+ return parent_ids.has(filter.id);
33
+ });
34
+ if (result.length === previous_length)
35
+ break;
36
+ }
37
+ return result;
38
+ };
39
+ const getFilteredFLs = (fls) => {
40
+ var _a, _b, _c;
41
+ let selected_item = (_a = state.chain) === null || _a === void 0 ? void 0 : _a[state.chain.length - 1];
42
+ if (selected_item)
43
+ return (_b = fls.filter(link => link.parent_id === selected_item.id)) !== null && _b !== void 0 ? _b : [];
44
+ if (props.search)
45
+ if (!SearchOperation.match(props.product.name, props.search))
46
+ return SearchOperation.filter(fls, item => { var _a; return (_a = item.name) !== null && _a !== void 0 ? _a : ""; }, props.search);
47
+ return (_c = fls.filter(link => link.parent_id === null)) !== null && _c !== void 0 ? _c : [];
48
+ };
49
+ function buildUniqueNameMap(fls) {
50
+ let name_map = new Map();
51
+ props.fls.forEach(fl => name_map.set(fl.id, fl));
52
+ function getNameChain(item) {
53
+ const chain = [];
54
+ let current = item;
55
+ while (current) {
56
+ if (current.name)
57
+ chain.unshift(current.name);
58
+ if (!current.parent_id)
59
+ break;
60
+ current = name_map.get(current.parent_id);
61
+ }
62
+ return chain;
63
+ }
64
+ const result = {};
65
+ for (const fl of fls)
66
+ result[fl.id] = getNameChain(fl).join(" / ");
67
+ return result;
68
+ }
69
+ const hasChildren = (fl) => {
70
+ var _a;
71
+ return ((_a = props.fls.findIndex(link => link.parent_id === fl.id)) !== null && _a !== void 0 ? _a : -1) > -1;
72
+ };
73
+ const getFilterLinkNode = (fl) => {
74
+ let fl_name = fl.name;
75
+ if (props.search && state.chain.length === 0)
76
+ fl_name = uniqe_name_map[fl.id];
77
+ if (hasChildren(fl))
78
+ return (_jsxs("div", { className: Styles.nsa_master_menu_list_content, onClick: () => {
79
+ setState((prev) => { var _a; return (Object.assign(Object.assign({}, prev), { chain: [...(_a = prev.chain) !== null && _a !== void 0 ? _a : [], fl] })); });
80
+ }, children: [_jsx("span", { className: Styles.nsa_master_menu_list_text, children: fl_name }), _jsx("img", { src: `https://static.namirasoft.com/image/concept/arrow/right/blue.svg`, alt: "angle", width: 10, height: 10, className: Styles.nsa_master_menu_arrow })] }));
81
+ return (_jsx("a", { href: fl.link.url, className: Styles.nsa_master_menu_list_content, children: _jsx("span", { className: Styles.nsa_master_menu_list_text, children: fl_name }) }));
82
+ };
83
+ useEffect(() => {
84
+ setState((prev) => (Object.assign(Object.assign({}, prev), { chain: [], active: !!props.search && filtered_fls.length > 0 })));
85
+ }, [props.search]);
86
+ let fls = useMemo(() => {
87
+ return getVisibleFLs(props.fls);
88
+ }, [props.product, props.fls]);
89
+ let filtered_fls = getFilteredFLs(fls);
90
+ let uniqe_name_map = buildUniqueNameMap(filtered_fls);
91
+ if (props.search && filtered_fls.length === 0)
92
+ if (!SearchOperation.match(props.product.name, props.search))
93
+ return _jsx(_Fragment, {});
94
+ let product_name = props.product.name.replace("Namirasoft ", "");
95
+ return (_jsxs("li", { className: Styles.nsa_master_menu_list_item, children: [_jsxs("figure", { className: Styles.nsa_master_menu_list_content, role: "button", title: product_name, onClick: () => {
96
+ setState((prev) => (Object.assign(Object.assign({}, prev), { chain: [], active: props.open ? !prev.active : true })));
97
+ props.onClick();
98
+ }, children: [_jsx("img", { src: (_a = props.product.logo) !== null && _a !== void 0 ? _a : "", alt: props.product.name, width: 24, height: 24, className: Styles.nsa_master_menu_logo }), _jsx("figcaption", { className: Styles.nsa_master_menu_list_text, children: product_name }), props.fls.length > 0 &&
99
+ _jsx("img", { src: `https://static.namirasoft.com/image/concept/arrow/${state.active ? "down" : "right"}/blue.svg`, alt: "angle", width: 12, height: 12, className: Styles.nsa_master_menu_arrow })] }), state.loading &&
100
+ _jsx(NSLoading, { small: true, hideDescription: true, hideTitle: true, style: { padding: "2rem 0" } }), state.active && filtered_fls.length > 0 &&
101
+ _jsxs("ul", { className: Styles.nsa_master_menu_list, children: [state.chain.length > 0 &&
102
+ _jsx("li", { className: Styles.nsa_master_menu_list_item, children: _jsx("div", { className: `${Styles.nsa_master_menu_list_content} ${Styles.back}`, onClick: () => {
103
+ setState((prev) => {
104
+ var _a;
105
+ (_a = prev.chain) === null || _a === void 0 ? void 0 : _a.pop();
106
+ return Object.assign(Object.assign({}, prev), { chain: prev.chain });
107
+ });
108
+ }, children: _jsx("span", { className: Styles.nsa_master_menu_list_text, children: ".." }) }) }), filtered_fls.map(item => (_jsx("li", { className: Styles.nsa_master_menu_list_item, children: getFilterLinkNode(item) }, item.id)))] })] }));
109
+ }
110
+ export default NSAMasterMenuItem;
111
+ //# sourceMappingURL=NSAMasterMenuItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NSAMasterMenuItem.js","sourceRoot":"","sources":["../../src/components/NSAMasterMenuItem.tsx"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
- import { Component } from 'react';
2
1
  import { ProductFullRow } from 'namirasoft-api-product';
3
2
  import { NSDialogProps } from 'namirasoft-site-react';
3
+ import { Component } from 'react';
4
4
  import { NSARouterMakerProps } from '../NSARouterMakerProps';
5
5
  export interface NSAProductListDialogProps extends NSARouterMakerProps, NSDialogProps {
6
6
  }