cloud-ide-layout 0.0.1 → 1.0.1

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 (81) hide show
  1. package/README.md +466 -13
  2. package/esm2022/lib/cloud-ide-layout.routes.mjs +24 -10
  3. package/esm2022/lib/layout/console/console-wrapper/console-wrapper.component.mjs +6 -6
  4. package/esm2022/lib/layout/console/console.service.mjs +28 -0
  5. package/esm2022/lib/layout/footer/footer-wrapper/footer-wrapper.component.mjs +16 -8
  6. package/esm2022/lib/layout/footer/footer.service.mjs +28 -0
  7. package/esm2022/lib/layout/header/header-wrapper/header-wrapper.component.mjs +69 -18
  8. package/esm2022/lib/layout/header/header.service.mjs +17 -6
  9. package/esm2022/lib/layout/home/home-wrapper/home-wrapper.component.mjs +194 -7
  10. package/esm2022/lib/layout/layout/layout-wrapper/layout-wrapper.component.mjs +18 -9
  11. package/esm2022/lib/layout/request/request-wrapper/request-wrapper.component.mjs +54 -6
  12. package/esm2022/lib/layout/request/request.service.mjs +235 -0
  13. package/esm2022/lib/layout/request/tab-content/tab-content.component.mjs +84 -0
  14. package/esm2022/lib/layout/shared/shared-wrapper/shared-wrapper.component.mjs +32 -20
  15. package/esm2022/lib/layout/shared/shared.service.mjs +490 -14
  16. package/esm2022/lib/layout/sidebar/sidebar-wrapper/sidebar-wrapper.component.mjs +480 -15
  17. package/esm2022/lib/layout/sidebar/sidebar.service.mjs +20 -7
  18. package/esm2022/lib/layout/sidedrawer/cide-lyt-drawer-base.class.mjs +40 -0
  19. package/esm2022/lib/layout/sidedrawer/drawer-theme/drawer-theme.component.mjs +296 -0
  20. package/esm2022/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.component.mjs +175 -0
  21. package/esm2022/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.service.mjs +51 -0
  22. package/esm2022/lib/layout/sidedrawer/sidedrawer-wrapper/sidedrawer-wrapper.component.mjs +254 -9
  23. package/esm2022/lib/layout/sidedrawer/sidedrawer.service.mjs +70 -0
  24. package/esm2022/lib/services/app-state/app-state-helper.service.mjs +222 -0
  25. package/esm2022/lib/services/app-state/app-state.service.mjs +256 -0
  26. package/esm2022/lib/services/app-state/index.mjs +3 -0
  27. package/esm2022/lib/services/cache-manager/cache-manager.service.mjs +112 -0
  28. package/esm2022/lib/services/file-manager/file-manager.service.mjs +7 -7
  29. package/esm2022/lib/services/tab-state.service.mjs +128 -0
  30. package/esm2022/lib/services/theme/theme.service.mjs +151 -0
  31. package/esm2022/lib/services/user-status/user-status.service.mjs +135 -0
  32. package/esm2022/lib/utils/custom-route-reuse-strategy.mjs +61 -0
  33. package/esm2022/lib/utils/index.mjs +2 -0
  34. package/esm2022/public-api.mjs +7 -1
  35. package/fesm2022/cloud-ide-layout-cloud-ide-layout-DqL3A73V.mjs +2914 -0
  36. package/fesm2022/cloud-ide-layout-cloud-ide-layout-DqL3A73V.mjs.map +1 -0
  37. package/fesm2022/cloud-ide-layout-drawer-theme.component-xd8IG3WP.mjs +443 -0
  38. package/fesm2022/cloud-ide-layout-drawer-theme.component-xd8IG3WP.mjs.map +1 -0
  39. package/fesm2022/cloud-ide-layout-home-wrapper.component-DEdsEiaq.mjs +197 -0
  40. package/fesm2022/cloud-ide-layout-home-wrapper.component-DEdsEiaq.mjs.map +1 -0
  41. package/fesm2022/cloud-ide-layout-sidedrawer-notes.component-ds12wZbh.mjs +260 -0
  42. package/fesm2022/cloud-ide-layout-sidedrawer-notes.component-ds12wZbh.mjs.map +1 -0
  43. package/fesm2022/cloud-ide-layout.mjs +1 -261
  44. package/fesm2022/cloud-ide-layout.mjs.map +1 -1
  45. package/lib/cloud-ide-layout.routes.d.ts +1 -0
  46. package/lib/layout/console/console-wrapper/console-wrapper.component.d.ts +3 -3
  47. package/lib/layout/console/console.service.d.ts +9 -0
  48. package/lib/layout/footer/footer-wrapper/footer-wrapper.component.d.ts +7 -3
  49. package/lib/layout/footer/footer.service.d.ts +9 -0
  50. package/lib/layout/header/header-wrapper/header-wrapper.component.d.ts +17 -9
  51. package/lib/layout/header/header.service.d.ts +4 -3
  52. package/lib/layout/home/home-wrapper/home-wrapper.component.d.ts +90 -1
  53. package/lib/layout/request/request-wrapper/request-wrapper.component.d.ts +10 -1
  54. package/lib/layout/request/request.service.d.ts +60 -0
  55. package/lib/layout/request/tab-content/tab-content.component.d.ts +19 -0
  56. package/lib/layout/shared/shared-wrapper/shared-wrapper.component.d.ts +4 -5
  57. package/lib/layout/shared/shared.service.d.ts +104 -6
  58. package/lib/layout/sidebar/sidebar-wrapper/sidebar-wrapper.component.d.ts +135 -6
  59. package/lib/layout/sidebar/sidebar.service.d.ts +3 -2
  60. package/lib/layout/sidedrawer/cide-lyt-drawer-base.class.d.ts +16 -0
  61. package/lib/layout/sidedrawer/drawer-theme/drawer-theme.component.d.ts +71 -0
  62. package/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.component.d.ts +48 -0
  63. package/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.service.d.ts +13 -0
  64. package/lib/layout/sidedrawer/sidedrawer-wrapper/sidedrawer-wrapper.component.d.ts +28 -3
  65. package/lib/layout/sidedrawer/sidedrawer.service.d.ts +30 -0
  66. package/lib/services/app-state/app-state-helper.service.d.ts +150 -0
  67. package/lib/services/app-state/app-state.service.d.ts +85 -0
  68. package/lib/services/app-state/index.d.ts +3 -0
  69. package/lib/services/cache-manager/cache-manager.service.d.ts +64 -0
  70. package/lib/services/file-manager/file-manager.service.d.ts +0 -2
  71. package/lib/services/tab-state.service.d.ts +79 -0
  72. package/lib/services/theme/theme.service.d.ts +71 -0
  73. package/lib/services/user-status/user-status.service.d.ts +57 -0
  74. package/lib/utils/custom-route-reuse-strategy.d.ts +15 -0
  75. package/lib/utils/index.d.ts +1 -0
  76. package/package.json +2 -2
  77. package/public-api.d.ts +4 -0
  78. package/src/lib/assets/css/cide-lyt-style.scss +182 -0
  79. package/src/lib/assets/css/cide-lyt-variable.scss +119 -0
  80. package/fesm2022/cloud-ide-layout-home-wrapper.component-BV7ptL0Y.mjs +0 -14
  81. package/fesm2022/cloud-ide-layout-home-wrapper.component-BV7ptL0Y.mjs.map +0 -1
@@ -1,12 +1,60 @@
1
- import { Component } from '@angular/core';
1
+ import { Component, ViewChildren } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
2
3
  import { CideIconComponent } from 'cloud-ide-element';
3
4
  import * as i0 from "@angular/core";
5
+ import * as i1 from "../request.service";
6
+ import * as i2 from "@angular/common";
4
7
  export class CideLytRequestWrapperComponent {
5
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
6
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: CideLytRequestWrapperComponent, isStandalone: true, selector: "cide-lyt-request-wrapper", ngImport: i0, template: "<div\r\n class=\"cide-request tw-w-[calc(100%-13rem-1.5rem)] tw-left-52 tw-right-6 tw-absolute tw-items-center tw-h-6 tw-border-b-gray-200 tw-border-solid tw-border-b tw-select-none tw-z-[100] tw-top-9 tw-justify-between tw-flex\">\r\n <div class=\"tw-h-full tw-items-center tw-inline-flex tw-text-xs tw-px-2 tw-text-gray-600\">\r\n Item master \r\n <cide-ele-icon class=\"tw-ml-3 tw-mt-[0.1rem]\" size=\"3xs\" type=\"box\">close</cide-ele-icon>\r\n <span class=\"tw-border-gray-100 tw-border-solid tw-border-r-2 tw-my-1 tw-h-4/5 tw-mx-2\"></span>\r\n <cide-ele-icon size=\"2xs\" type=\"box\">add</cide-ele-icon>\r\n </div>\r\n</div>", styles: [""], dependencies: [{ kind: "component", type: CideIconComponent, selector: "cide-ele-icon", inputs: ["size", "type", "toolTip"] }] }); }
8
+ constructor(requestService) {
9
+ this.requestService = requestService;
10
+ // Modern Signal-based access for better performance
11
+ this.requestItems = this.requestService.tabs;
12
+ }
13
+ ngAfterViewInit() {
14
+ // Apply entrance animation to initial items
15
+ this.applyAnimations();
16
+ // Listen for changes in request items and apply animations
17
+ this.requestItemElements.changes.subscribe({
18
+ next: () => {
19
+ this.applyAnimations();
20
+ }
21
+ });
22
+ }
23
+ // Apply animations to request items
24
+ applyAnimations() {
25
+ if (!this.requestItemElements)
26
+ return;
27
+ this.requestItemElements.forEach((itemEl) => {
28
+ const element = itemEl.nativeElement;
29
+ element.classList.remove('request-item-enter');
30
+ void element.offsetWidth; // Force reflow
31
+ element.classList.add('request-item-enter');
32
+ });
33
+ }
34
+ // Apply flicker effect to clicked item
35
+ applyFlickerEffect(event) {
36
+ const target = event.currentTarget;
37
+ if (target) {
38
+ // Remove any existing flicker class
39
+ target.classList.remove('request-item-flicker');
40
+ // Force reflow to ensure the class removal is processed
41
+ void target.offsetWidth;
42
+ // Add flicker class to trigger animation
43
+ target.classList.add('request-item-flicker');
44
+ // Remove the class after animation completes
45
+ setTimeout(() => {
46
+ target.classList.remove('request-item-flicker');
47
+ }, 400); // Match the animation duration
48
+ }
49
+ }
50
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestWrapperComponent, deps: [{ token: i1.CideLytRequestService }], target: i0.ɵɵFactoryTarget.Component }); }
51
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: CideLytRequestWrapperComponent, isStandalone: true, selector: "cide-lyt-request-wrapper", viewQueries: [{ propertyName: "requestItemElements", predicate: ["requestItemEl"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"requestItems() as requestItems\">\n <div id=\"cide-lyt-request-wrapper\" class=\"cide-lyt-request tw-w-[inherit]\" [class.cide-lyt-request-wrapper-hide]=\"!requestItems.length\">\n <div class=\"request-content tw-flex tw-items-center tw-overflow-x-auto\">\n <ng-container *ngFor=\"let item of requestItems; let i = index\">\n <div #requestItemEl class=\"request-item\" (keydown.enter)=\"requestService.activateTab(item.id); applyFlickerEffect($event)\"\n [class.active]=\"item.active\" tabindex=\"0\" (click)=\"requestService.activateTab(item.id); applyFlickerEffect($event)\"\n [attr.data-tooltip]=\"item.title\">\n <span class=\"request-title\">{{ item.title }}</span>\n <button class=\"request-action close-action\" \n (click)=\"requestService.closeTab(item.id); $event.stopPropagation();\"\n (keydown.enter)=\"requestService.closeTab(item.id); $event.stopPropagation();\" \n tabindex=\"0\"\n data-tooltip=\"Close this tab\">\n <cide-ele-icon size=\"3xs\">close</cide-ele-icon>\n </button>\n </div>\n <!-- Only add divider between items -->\n <div class=\"request-divider\" *ngIf=\"i < requestItems.length - 1\"></div>\n </ng-container>\n </div>\n </div>\n</ng-container>", styles: [".cide-lyt-request{height:20px;background:linear-gradient(to right,#fff,#f9fafbf2);border-bottom:1px solid rgba(229,231,235,.8);box-shadow:0 2px 6px #0000000d,0 1px 1px #00000008;display:flex;align-items:center;padding:0 .5rem;position:relative;z-index:15;transition:all .2s cubic-bezier(.4,0,.2,1);will-change:transform;-webkit-user-select:none;user-select:none;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.request-content{display:flex;align-items:center;height:100%;width:100%;position:relative;overflow:hidden}.request-item{position:relative;padding:8px 12px;margin:0 4px;border-radius:.375rem;display:flex;align-items:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);overflow:hidden;background-color:#fff9;box-shadow:0 1px 2px #00000005;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(229,231,235,.4)}.request-item:hover{background-color:#ffffffe6;transform:translateY(-1px);box-shadow:0 2px 5px #0000000d;border-color:#d1d5db99}.request-item:active{transform:translateY(0);box-shadow:0 1px 2px #00000008}.request-item.active{background:#eff6ffcc;border-color:#3b82f64d;box-shadow:0 2px 6px #3b82f61a,0 0 0 1px #3b82f626;position:relative}@keyframes shimmerGradient{0%{background-position:100% 50%}to{background-position:0% 50%}}.request-title{font-size:.875rem;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s ease}.request-item.active .request-title{color:#2563eb;font-weight:500;text-shadow:0 0 1px rgba(37,99,235,.1)}.request-action,.request-add-action{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background-color:transparent;transition:all .2s ease}.request-action:hover,.request-add-action:hover{background-color:#f3f4f6cc;transform:scale(1.1)}.request-action:active,.request-add-action:active{transform:scale(.95)}:host-context(.dark-mode) .cide-lyt-request{background:linear-gradient(to right,#0f172a,#0f172af2);border-bottom-color:#1e293be6;box-shadow:0 2px 6px #00000026,0 1px 1px #0000001a}:host-context(.dark-mode) .request-item{background-color:#1e293b99;border-color:#33415566;box-shadow:0 1px 2px #0000001a}:host-context(.dark-mode) .request-item:hover{background-color:#1e293bcc;border-color:#47556999;box-shadow:0 2px 5px #00000026}:host-context(.dark-mode) .request-title{color:#e2e8f0}:host-context(.dark-mode) .request-item:hover .request-title{color:#f8fafc}:host-context(.dark-mode) .request-item.active{background:#1e3a8a4d;border-color:#3b82f666;box-shadow:0 2px 6px #1e40af40,0 0 0 1px #3b82f633}:host-context(.dark-mode) .request-item.active .request-title{color:#60a5fa;text-shadow:0 0 2px rgba(96,165,250,.2)}:host-context(.dark-mode) .request-action:hover,:host-context(.dark-mode) .request-add-action:hover{background-color:#334155cc}.request-item:hover{transform:translateY(-.5px);box-shadow:0 1px 3px #00000008}.request-item:hover:before{opacity:1}.request-item.active{background:linear-gradient(to right,#eff6ffcc,#dbeafe99);box-shadow:0 1px 3px #3b82f626;transform:translateZ(0)}@keyframes glowEffect{0%{opacity:.6;box-shadow:0 1px 2px #3b82f61a}50%{opacity:1;box-shadow:0 1px 3px #3b82f64d}to{opacity:.6;box-shadow:0 1px 2px #3b82f61a}}.request-title{font-size:.7rem;color:#374151;margin-right:.5rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;letter-spacing:.01em;transition:all .2s ease;position:relative}.request-item.active .request-title{color:#1e40af;font-weight:600;text-shadow:0 0 .5px rgba(37,99,235,.3);letter-spacing:.015em}.request-action{display:flex;align-items:center;justify-content:center;height:14px;width:14px;border-radius:3px;transition:all .2s ease;cursor:pointer;color:#9ca3af;border:none;background:transparent;padding:0;outline:none;position:relative;overflow:hidden;transform:translateZ(0)}.request-action:hover{background-color:#3b82f614;color:#3b82f6;transform:translateY(-.5px) scale(1.05);box-shadow:0 1px 2px #0000000d}.request-action:active{transform:translateY(.5px) scale(.97);transition:all .1s ease}.request-action:focus-visible{outline:1px solid #3b82f6;outline-offset:1px;box-shadow:0 0 0 2px #3b82f61a}.close-action:hover{background-color:#ef444414;color:#ef4444}.close-action:focus-visible{outline-color:#ef4444;box-shadow:0 0 0 2px #ef44441a}.request-divider{width:1px;height:18px;background:linear-gradient(to bottom,#d1d5db1a,#d1d5db80,#d1d5db1a);margin:0 4px}:host-context(.dark-mode) .request-divider{background:linear-gradient(to bottom,#4755691a,#47556980,#4755691a)}.request-divider:before{content:\"\";position:absolute;top:0;bottom:0;left:-1px;width:3px;background:radial-gradient(ellipse at center,#ffffff80,#fff0 70%);opacity:0;transition:opacity .3s ease}.request-content:hover .request-divider:before{opacity:.7}.request-add-action{display:flex;align-items:center;justify-content:center;height:16px;width:16px;border-radius:3px;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;color:#6b7280;background-color:transparent;border:none;padding:0;outline:none;position:relative;overflow:hidden}.request-add-action:hover{background-color:#3b82f614;color:#3b82f6;transform:translateY(-.5px) scale(1.05);box-shadow:0 1px 3px #3b82f626}.request-add-action:active{transform:translateY(.5px) scale(.97);transition:all .1s ease}.request-add-action:focus-visible{outline:1px solid #3b82f6;outline-offset:1px;box-shadow:0 0 0 2px #3b82f61a}.request-add-action:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle,#3b82f64d,#3b82f600 70%);opacity:0;transform:scale(0);transition:transform .4s ease,opacity .3s ease}.request-add-action:active:after{opacity:1;transform:scale(3);transition:transform .1s ease,opacity .1s ease}@keyframes subtlePulse{0%{box-shadow:0 0 #3b82f600;transform:scale(1)}50%{box-shadow:0 0 0 3px #3b82f626;transform:scale(1.05)}to{box-shadow:0 0 #3b82f600;transform:scale(1)}}.request-add-action-pulse{animation:subtlePulse 2s cubic-bezier(.4,0,.6,1) infinite}:host-context(.dark-mode) .cide-lyt-request{background:linear-gradient(to right,#111827f2,#1f2937e6);border-bottom:1px solid rgba(55,65,81,.5)}:host-context(.dark-mode) .request-title{color:#e5e7eb}:host-context(.dark-mode) .request-item.active{background:linear-gradient(to right,#1e3a8a26,#2563eb1a)}:host-context(.dark-mode) .request-item.active .request-title{color:#93c5fd}:host-context(.dark-mode) .request-action,:host-context(.dark-mode) .request-add-action{color:#9ca3af}:host-context(.dark-mode) .request-divider{background:linear-gradient(to bottom,#4b55634d,#6b728080,#4b55634d)}@keyframes slideIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-5px)}}@keyframes flickerEffect{0%{opacity:1;transform:scale(1);box-shadow:0 1px 2px #00000005}25%{opacity:.7;transform:scale(.98);box-shadow:0 2px 8px #3b82f64d}50%{opacity:.9;transform:scale(1.02);box-shadow:0 4px 12px #3b82f666}75%{opacity:.8;transform:scale(.99);box-shadow:0 2px 6px #3b82f633}to{opacity:1;transform:scale(1);box-shadow:0 1px 2px #00000005}}@keyframes flickerEffectDark{0%{opacity:1;transform:scale(1);box-shadow:0 1px 2px #0000001a}25%{opacity:.7;transform:scale(.98);box-shadow:0 2px 8px #60a5fa4d}50%{opacity:.9;transform:scale(1.02);box-shadow:0 4px 12px #60a5fa66}75%{opacity:.8;transform:scale(.99);box-shadow:0 2px 6px #60a5fa33}to{opacity:1;transform:scale(1);box-shadow:0 1px 2px #0000001a}}.request-item-enter{animation:slideIn .2s cubic-bezier(.4,0,.2,1)}.request-item-exit{animation:slideOut .2s cubic-bezier(.4,0,.2,1)}.request-item-flicker{animation:flickerEffect .4s cubic-bezier(.4,0,.2,1)}:host-context(.dark-mode) .request-item-flicker{animation:flickerEffectDark .4s cubic-bezier(.4,0,.2,1)}@media (max-width: 640px){.request-title{max-width:80px}}.request-item:focus,.request-action:focus,.request-add-action:focus{outline:none;box-shadow:0 0 0 2px #3b82f64d}:host-context(.dark-mode) .request-item:focus,:host-context(.dark-mode) .request-action:focus,:host-context(.dark-mode) .request-add-action:focus{box-shadow:0 0 0 2px #60a5fa66}.cide-lyt-request:hover{box-shadow:0 3px 8px #00000012,0 1px 2px #0000000d;transform:translateY(-1px)}.request-content:empty .request-add-action{animation:pulseAttention 2s infinite}@keyframes pulseAttention{0%{box-shadow:0 0 #3b82f666;transform:scale(1)}70%{box-shadow:0 0 0 8px #3b82f600;transform:scale(1.05)}to{box-shadow:0 0 #3b82f600;transform:scale(1)}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { 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: CideIconComponent, selector: "cide-ele-icon", inputs: ["size", "type", "toolTip"] }] }); }
7
52
  }
8
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestWrapperComponent, decorators: [{
9
54
  type: Component,
10
- args: [{ selector: 'cide-lyt-request-wrapper', standalone: true, imports: [CideIconComponent], template: "<div\r\n class=\"cide-request tw-w-[calc(100%-13rem-1.5rem)] tw-left-52 tw-right-6 tw-absolute tw-items-center tw-h-6 tw-border-b-gray-200 tw-border-solid tw-border-b tw-select-none tw-z-[100] tw-top-9 tw-justify-between tw-flex\">\r\n <div class=\"tw-h-full tw-items-center tw-inline-flex tw-text-xs tw-px-2 tw-text-gray-600\">\r\n Item master \r\n <cide-ele-icon class=\"tw-ml-3 tw-mt-[0.1rem]\" size=\"3xs\" type=\"box\">close</cide-ele-icon>\r\n <span class=\"tw-border-gray-100 tw-border-solid tw-border-r-2 tw-my-1 tw-h-4/5 tw-mx-2\"></span>\r\n <cide-ele-icon size=\"2xs\" type=\"box\">add</cide-ele-icon>\r\n </div>\r\n</div>" }]
11
- }] });
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nsb3VkLWlkZS1sYXlvdXQvc3JjL2xpYi9sYXlvdXQvcmVxdWVzdC9yZXF1ZXN0LXdyYXBwZXIvcmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nsb3VkLWlkZS1sYXlvdXQvc3JjL2xpYi9sYXlvdXQvcmVxdWVzdC9yZXF1ZXN0LXdyYXBwZXIvcmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBU3RELE1BQU0sT0FBTyw4QkFBOEI7OEdBQTlCLDhCQUE4QjtrR0FBOUIsOEJBQThCLG9GQ1YzQyxncUJBUU0sMERERk0saUJBQWlCOzsyRkFJaEIsOEJBQThCO2tCQVAxQyxTQUFTOytCQUNFLDBCQUEwQixjQUN4QixJQUFJLFdBQ1AsQ0FBQyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDaWRlSWNvbkNvbXBvbmVudCB9IGZyb20gJ2Nsb3VkLWlkZS1lbGVtZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY2lkZS1seXQtcmVxdWVzdC13cmFwcGVyJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtDaWRlSWNvbkNvbXBvbmVudF0sXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3JlcXVlc3Qtd3JhcHBlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL3JlcXVlc3Qtd3JhcHBlci5jb21wb25lbnQuY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2lkZUx5dFJlcXVlc3RXcmFwcGVyQ29tcG9uZW50IHtcclxuXHJcbn1cclxuIiwiPGRpdlxyXG4gICAgY2xhc3M9XCJjaWRlLXJlcXVlc3QgdHctdy1bY2FsYygxMDAlLTEzcmVtLTEuNXJlbSldIHR3LWxlZnQtNTIgdHctcmlnaHQtNiB0dy1hYnNvbHV0ZSB0dy1pdGVtcy1jZW50ZXIgdHctaC02IHR3LWJvcmRlci1iLWdyYXktMjAwIHR3LWJvcmRlci1zb2xpZCB0dy1ib3JkZXItYiB0dy1zZWxlY3Qtbm9uZSB0dy16LVsxMDBdIHR3LXRvcC05IHR3LWp1c3RpZnktYmV0d2VlbiB0dy1mbGV4XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwidHctaC1mdWxsIHR3LWl0ZW1zLWNlbnRlciB0dy1pbmxpbmUtZmxleCB0dy10ZXh0LXhzIHR3LXB4LTIgdHctdGV4dC1ncmF5LTYwMFwiPlxyXG4gICAgICAgIEl0ZW0gbWFzdGVyIFxyXG4gICAgICAgIDxjaWRlLWVsZS1pY29uIGNsYXNzPVwidHctbWwtMyB0dy1tdC1bMC4xcmVtXVwiIHNpemU9XCIzeHNcIiB0eXBlPVwiYm94XCI+Y2xvc2U8L2NpZGUtZWxlLWljb24+XHJcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJ0dy1ib3JkZXItZ3JheS0xMDAgdHctYm9yZGVyLXNvbGlkIHR3LWJvcmRlci1yLTIgdHctbXktMSB0dy1oLTQvNSB0dy1teC0yXCI+PC9zcGFuPlxyXG4gICAgICAgIDxjaWRlLWVsZS1pY29uIHNpemU9XCIyeHNcIiB0eXBlPVwiYm94XCI+YWRkPC9jaWRlLWVsZS1pY29uPlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PiJdfQ==
55
+ args: [{ selector: 'cide-lyt-request-wrapper', standalone: true, imports: [CommonModule, CideIconComponent], template: "<ng-container *ngIf=\"requestItems() as requestItems\">\n <div id=\"cide-lyt-request-wrapper\" class=\"cide-lyt-request tw-w-[inherit]\" [class.cide-lyt-request-wrapper-hide]=\"!requestItems.length\">\n <div class=\"request-content tw-flex tw-items-center tw-overflow-x-auto\">\n <ng-container *ngFor=\"let item of requestItems; let i = index\">\n <div #requestItemEl class=\"request-item\" (keydown.enter)=\"requestService.activateTab(item.id); applyFlickerEffect($event)\"\n [class.active]=\"item.active\" tabindex=\"0\" (click)=\"requestService.activateTab(item.id); applyFlickerEffect($event)\"\n [attr.data-tooltip]=\"item.title\">\n <span class=\"request-title\">{{ item.title }}</span>\n <button class=\"request-action close-action\" \n (click)=\"requestService.closeTab(item.id); $event.stopPropagation();\"\n (keydown.enter)=\"requestService.closeTab(item.id); $event.stopPropagation();\" \n tabindex=\"0\"\n data-tooltip=\"Close this tab\">\n <cide-ele-icon size=\"3xs\">close</cide-ele-icon>\n </button>\n </div>\n <!-- Only add divider between items -->\n <div class=\"request-divider\" *ngIf=\"i < requestItems.length - 1\"></div>\n </ng-container>\n </div>\n </div>\n</ng-container>", styles: [".cide-lyt-request{height:20px;background:linear-gradient(to right,#fff,#f9fafbf2);border-bottom:1px solid rgba(229,231,235,.8);box-shadow:0 2px 6px #0000000d,0 1px 1px #00000008;display:flex;align-items:center;padding:0 .5rem;position:relative;z-index:15;transition:all .2s cubic-bezier(.4,0,.2,1);will-change:transform;-webkit-user-select:none;user-select:none;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.request-content{display:flex;align-items:center;height:100%;width:100%;position:relative;overflow:hidden}.request-item{position:relative;padding:8px 12px;margin:0 4px;border-radius:.375rem;display:flex;align-items:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);overflow:hidden;background-color:#fff9;box-shadow:0 1px 2px #00000005;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(229,231,235,.4)}.request-item:hover{background-color:#ffffffe6;transform:translateY(-1px);box-shadow:0 2px 5px #0000000d;border-color:#d1d5db99}.request-item:active{transform:translateY(0);box-shadow:0 1px 2px #00000008}.request-item.active{background:#eff6ffcc;border-color:#3b82f64d;box-shadow:0 2px 6px #3b82f61a,0 0 0 1px #3b82f626;position:relative}@keyframes shimmerGradient{0%{background-position:100% 50%}to{background-position:0% 50%}}.request-title{font-size:.875rem;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s ease}.request-item.active .request-title{color:#2563eb;font-weight:500;text-shadow:0 0 1px rgba(37,99,235,.1)}.request-action,.request-add-action{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background-color:transparent;transition:all .2s ease}.request-action:hover,.request-add-action:hover{background-color:#f3f4f6cc;transform:scale(1.1)}.request-action:active,.request-add-action:active{transform:scale(.95)}:host-context(.dark-mode) .cide-lyt-request{background:linear-gradient(to right,#0f172a,#0f172af2);border-bottom-color:#1e293be6;box-shadow:0 2px 6px #00000026,0 1px 1px #0000001a}:host-context(.dark-mode) .request-item{background-color:#1e293b99;border-color:#33415566;box-shadow:0 1px 2px #0000001a}:host-context(.dark-mode) .request-item:hover{background-color:#1e293bcc;border-color:#47556999;box-shadow:0 2px 5px #00000026}:host-context(.dark-mode) .request-title{color:#e2e8f0}:host-context(.dark-mode) .request-item:hover .request-title{color:#f8fafc}:host-context(.dark-mode) .request-item.active{background:#1e3a8a4d;border-color:#3b82f666;box-shadow:0 2px 6px #1e40af40,0 0 0 1px #3b82f633}:host-context(.dark-mode) .request-item.active .request-title{color:#60a5fa;text-shadow:0 0 2px rgba(96,165,250,.2)}:host-context(.dark-mode) .request-action:hover,:host-context(.dark-mode) .request-add-action:hover{background-color:#334155cc}.request-item:hover{transform:translateY(-.5px);box-shadow:0 1px 3px #00000008}.request-item:hover:before{opacity:1}.request-item.active{background:linear-gradient(to right,#eff6ffcc,#dbeafe99);box-shadow:0 1px 3px #3b82f626;transform:translateZ(0)}@keyframes glowEffect{0%{opacity:.6;box-shadow:0 1px 2px #3b82f61a}50%{opacity:1;box-shadow:0 1px 3px #3b82f64d}to{opacity:.6;box-shadow:0 1px 2px #3b82f61a}}.request-title{font-size:.7rem;color:#374151;margin-right:.5rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;letter-spacing:.01em;transition:all .2s ease;position:relative}.request-item.active .request-title{color:#1e40af;font-weight:600;text-shadow:0 0 .5px rgba(37,99,235,.3);letter-spacing:.015em}.request-action{display:flex;align-items:center;justify-content:center;height:14px;width:14px;border-radius:3px;transition:all .2s ease;cursor:pointer;color:#9ca3af;border:none;background:transparent;padding:0;outline:none;position:relative;overflow:hidden;transform:translateZ(0)}.request-action:hover{background-color:#3b82f614;color:#3b82f6;transform:translateY(-.5px) scale(1.05);box-shadow:0 1px 2px #0000000d}.request-action:active{transform:translateY(.5px) scale(.97);transition:all .1s ease}.request-action:focus-visible{outline:1px solid #3b82f6;outline-offset:1px;box-shadow:0 0 0 2px #3b82f61a}.close-action:hover{background-color:#ef444414;color:#ef4444}.close-action:focus-visible{outline-color:#ef4444;box-shadow:0 0 0 2px #ef44441a}.request-divider{width:1px;height:18px;background:linear-gradient(to bottom,#d1d5db1a,#d1d5db80,#d1d5db1a);margin:0 4px}:host-context(.dark-mode) .request-divider{background:linear-gradient(to bottom,#4755691a,#47556980,#4755691a)}.request-divider:before{content:\"\";position:absolute;top:0;bottom:0;left:-1px;width:3px;background:radial-gradient(ellipse at center,#ffffff80,#fff0 70%);opacity:0;transition:opacity .3s ease}.request-content:hover .request-divider:before{opacity:.7}.request-add-action{display:flex;align-items:center;justify-content:center;height:16px;width:16px;border-radius:3px;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;color:#6b7280;background-color:transparent;border:none;padding:0;outline:none;position:relative;overflow:hidden}.request-add-action:hover{background-color:#3b82f614;color:#3b82f6;transform:translateY(-.5px) scale(1.05);box-shadow:0 1px 3px #3b82f626}.request-add-action:active{transform:translateY(.5px) scale(.97);transition:all .1s ease}.request-add-action:focus-visible{outline:1px solid #3b82f6;outline-offset:1px;box-shadow:0 0 0 2px #3b82f61a}.request-add-action:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle,#3b82f64d,#3b82f600 70%);opacity:0;transform:scale(0);transition:transform .4s ease,opacity .3s ease}.request-add-action:active:after{opacity:1;transform:scale(3);transition:transform .1s ease,opacity .1s ease}@keyframes subtlePulse{0%{box-shadow:0 0 #3b82f600;transform:scale(1)}50%{box-shadow:0 0 0 3px #3b82f626;transform:scale(1.05)}to{box-shadow:0 0 #3b82f600;transform:scale(1)}}.request-add-action-pulse{animation:subtlePulse 2s cubic-bezier(.4,0,.6,1) infinite}:host-context(.dark-mode) .cide-lyt-request{background:linear-gradient(to right,#111827f2,#1f2937e6);border-bottom:1px solid rgba(55,65,81,.5)}:host-context(.dark-mode) .request-title{color:#e5e7eb}:host-context(.dark-mode) .request-item.active{background:linear-gradient(to right,#1e3a8a26,#2563eb1a)}:host-context(.dark-mode) .request-item.active .request-title{color:#93c5fd}:host-context(.dark-mode) .request-action,:host-context(.dark-mode) .request-add-action{color:#9ca3af}:host-context(.dark-mode) .request-divider{background:linear-gradient(to bottom,#4b55634d,#6b728080,#4b55634d)}@keyframes slideIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-5px)}}@keyframes flickerEffect{0%{opacity:1;transform:scale(1);box-shadow:0 1px 2px #00000005}25%{opacity:.7;transform:scale(.98);box-shadow:0 2px 8px #3b82f64d}50%{opacity:.9;transform:scale(1.02);box-shadow:0 4px 12px #3b82f666}75%{opacity:.8;transform:scale(.99);box-shadow:0 2px 6px #3b82f633}to{opacity:1;transform:scale(1);box-shadow:0 1px 2px #00000005}}@keyframes flickerEffectDark{0%{opacity:1;transform:scale(1);box-shadow:0 1px 2px #0000001a}25%{opacity:.7;transform:scale(.98);box-shadow:0 2px 8px #60a5fa4d}50%{opacity:.9;transform:scale(1.02);box-shadow:0 4px 12px #60a5fa66}75%{opacity:.8;transform:scale(.99);box-shadow:0 2px 6px #60a5fa33}to{opacity:1;transform:scale(1);box-shadow:0 1px 2px #0000001a}}.request-item-enter{animation:slideIn .2s cubic-bezier(.4,0,.2,1)}.request-item-exit{animation:slideOut .2s cubic-bezier(.4,0,.2,1)}.request-item-flicker{animation:flickerEffect .4s cubic-bezier(.4,0,.2,1)}:host-context(.dark-mode) .request-item-flicker{animation:flickerEffectDark .4s cubic-bezier(.4,0,.2,1)}@media (max-width: 640px){.request-title{max-width:80px}}.request-item:focus,.request-action:focus,.request-add-action:focus{outline:none;box-shadow:0 0 0 2px #3b82f64d}:host-context(.dark-mode) .request-item:focus,:host-context(.dark-mode) .request-action:focus,:host-context(.dark-mode) .request-add-action:focus{box-shadow:0 0 0 2px #60a5fa66}.cide-lyt-request:hover{box-shadow:0 3px 8px #00000012,0 1px 2px #0000000d;transform:translateY(-1px)}.request-content:empty .request-add-action{animation:pulseAttention 2s infinite}@keyframes pulseAttention{0%{box-shadow:0 0 #3b82f666;transform:scale(1)}70%{box-shadow:0 0 0 8px #3b82f600;transform:scale(1.05)}to{box-shadow:0 0 #3b82f600;transform:scale(1)}}\n"] }]
56
+ }], ctorParameters: () => [{ type: i1.CideLytRequestService }], propDecorators: { requestItemElements: [{
57
+ type: ViewChildren,
58
+ args: ['requestItemEl']
59
+ }] } });
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nsb3VkLWlkZS1sYXlvdXQvc3JjL2xpYi9sYXlvdXQvcmVxdWVzdC9yZXF1ZXN0LXdyYXBwZXIvcmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nsb3VkLWlkZS1sYXlvdXQvc3JjL2xpYi9sYXlvdXQvcmVxdWVzdC9yZXF1ZXN0LXdyYXBwZXIvcmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsWUFBWSxFQUE0QixNQUFNLGVBQWUsQ0FBQztBQUM5RixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7Ozs7QUFVdEQsTUFBTSxPQUFPLDhCQUE4QjtJQU16QyxZQUNTLGNBQXFDO1FBQXJDLG1CQUFjLEdBQWQsY0FBYyxDQUF1QjtRQUo5QyxvREFBb0Q7UUFDN0MsaUJBQVksR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztJQUk1QyxDQUFDO0lBRUosZUFBZTtRQUNiLDRDQUE0QztRQUM1QyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFdkIsMkRBQTJEO1FBQzNELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDO1lBQ3pDLElBQUksRUFBRSxHQUFHLEVBQUU7Z0JBQ1QsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1lBQ3pCLENBQUM7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsb0NBQW9DO0lBQzVCLGVBQWU7UUFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxtQkFBbUI7WUFBRSxPQUFPO1FBRXRDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFrQixFQUFFLEVBQUU7WUFDdEQsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQztZQUNyQyxPQUFPLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1lBQy9DLEtBQUssT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDLGVBQWU7WUFDekMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUM5QyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCx1Q0FBdUM7SUFDdkMsa0JBQWtCLENBQUMsS0FBWTtRQUM3QixNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsYUFBNEIsQ0FBQztRQUNsRCxJQUFJLE1BQU0sRUFBRSxDQUFDO1lBQ1gsb0NBQW9DO1lBQ3BDLE1BQU0sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQUM7WUFFaEQsd0RBQXdEO1lBQ3hELEtBQUssTUFBTSxDQUFDLFdBQVcsQ0FBQztZQUV4Qix5Q0FBeUM7WUFDekMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsc0JBQXNCLENBQUMsQ0FBQztZQUU3Qyw2Q0FBNkM7WUFDN0MsVUFBVSxDQUFDLEdBQUcsRUFBRTtnQkFDZCxNQUFNLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO1lBQ2xELENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLCtCQUErQjtRQUMxQyxDQUFDO0lBQ0gsQ0FBQzs4R0FwRFUsOEJBQThCO2tHQUE5Qiw4QkFBOEIsNkxDWjNDLHMrQ0FxQmUsODVRRGJILFlBQVksZ1FBQUUsaUJBQWlCOzsyRkFJOUIsOEJBQThCO2tCQVAxQyxTQUFTOytCQUNFLDBCQUEwQixjQUN4QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsaUJBQWlCLENBQUM7MEZBS1gsbUJBQW1CO3NCQUFqRCxZQUFZO3VCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIFZpZXdDaGlsZHJlbiwgUXVlcnlMaXN0LCBBZnRlclZpZXdJbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2lkZUljb25Db21wb25lbnQgfSBmcm9tICdjbG91ZC1pZGUtZWxlbWVudCc7XG5pbXBvcnQgeyBDaWRlTHl0UmVxdWVzdFNlcnZpY2UgfSBmcm9tICcuLi9yZXF1ZXN0LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjaWRlLWx5dC1yZXF1ZXN0LXdyYXBwZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBDaWRlSWNvbkNvbXBvbmVudF0sXG4gIHRlbXBsYXRlVXJsOiAnLi9yZXF1ZXN0LXdyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vcmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC5jc3MnXG59KVxuZXhwb3J0IGNsYXNzIENpZGVMeXRSZXF1ZXN0V3JhcHBlckNvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xuICBAVmlld0NoaWxkcmVuKCdyZXF1ZXN0SXRlbUVsJykgcmVxdWVzdEl0ZW1FbGVtZW50cyE6IFF1ZXJ5TGlzdDxFbGVtZW50UmVmPjtcbiAgXG4gIC8vIE1vZGVybiBTaWduYWwtYmFzZWQgYWNjZXNzIGZvciBiZXR0ZXIgcGVyZm9ybWFuY2VcbiAgcHVibGljIHJlcXVlc3RJdGVtcyA9IHRoaXMucmVxdWVzdFNlcnZpY2UudGFicztcbiAgXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZXF1ZXN0U2VydmljZTogQ2lkZUx5dFJlcXVlc3RTZXJ2aWNlXG4gICkge31cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgLy8gQXBwbHkgZW50cmFuY2UgYW5pbWF0aW9uIHRvIGluaXRpYWwgaXRlbXNcbiAgICB0aGlzLmFwcGx5QW5pbWF0aW9ucygpO1xuICAgIFxuICAgIC8vIExpc3RlbiBmb3IgY2hhbmdlcyBpbiByZXF1ZXN0IGl0ZW1zIGFuZCBhcHBseSBhbmltYXRpb25zXG4gICAgdGhpcy5yZXF1ZXN0SXRlbUVsZW1lbnRzLmNoYW5nZXMuc3Vic2NyaWJlKHtcbiAgICAgIG5leHQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy5hcHBseUFuaW1hdGlvbnMoKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIC8vIEFwcGx5IGFuaW1hdGlvbnMgdG8gcmVxdWVzdCBpdGVtc1xuICBwcml2YXRlIGFwcGx5QW5pbWF0aW9ucygpIHtcbiAgICBpZiAoIXRoaXMucmVxdWVzdEl0ZW1FbGVtZW50cykgcmV0dXJuO1xuICAgIFxuICAgIHRoaXMucmVxdWVzdEl0ZW1FbGVtZW50cy5mb3JFYWNoKChpdGVtRWw6IEVsZW1lbnRSZWYpID0+IHtcbiAgICAgIGNvbnN0IGVsZW1lbnQgPSBpdGVtRWwubmF0aXZlRWxlbWVudDtcbiAgICAgIGVsZW1lbnQuY2xhc3NMaXN0LnJlbW92ZSgncmVxdWVzdC1pdGVtLWVudGVyJyk7XG4gICAgICB2b2lkIGVsZW1lbnQub2Zmc2V0V2lkdGg7IC8vIEZvcmNlIHJlZmxvd1xuICAgICAgZWxlbWVudC5jbGFzc0xpc3QuYWRkKCdyZXF1ZXN0LWl0ZW0tZW50ZXInKTtcbiAgICB9KTtcbiAgfVxuXG4gIC8vIEFwcGx5IGZsaWNrZXIgZWZmZWN0IHRvIGNsaWNrZWQgaXRlbVxuICBhcHBseUZsaWNrZXJFZmZlY3QoZXZlbnQ6IEV2ZW50KTogdm9pZCB7XG4gICAgY29uc3QgdGFyZ2V0ID0gZXZlbnQuY3VycmVudFRhcmdldCBhcyBIVE1MRWxlbWVudDtcbiAgICBpZiAodGFyZ2V0KSB7XG4gICAgICAvLyBSZW1vdmUgYW55IGV4aXN0aW5nIGZsaWNrZXIgY2xhc3NcbiAgICAgIHRhcmdldC5jbGFzc0xpc3QucmVtb3ZlKCdyZXF1ZXN0LWl0ZW0tZmxpY2tlcicpO1xuICAgICAgXG4gICAgICAvLyBGb3JjZSByZWZsb3cgdG8gZW5zdXJlIHRoZSBjbGFzcyByZW1vdmFsIGlzIHByb2Nlc3NlZFxuICAgICAgdm9pZCB0YXJnZXQub2Zmc2V0V2lkdGg7XG4gICAgICBcbiAgICAgIC8vIEFkZCBmbGlja2VyIGNsYXNzIHRvIHRyaWdnZXIgYW5pbWF0aW9uXG4gICAgICB0YXJnZXQuY2xhc3NMaXN0LmFkZCgncmVxdWVzdC1pdGVtLWZsaWNrZXInKTtcbiAgICAgIFxuICAgICAgLy8gUmVtb3ZlIHRoZSBjbGFzcyBhZnRlciBhbmltYXRpb24gY29tcGxldGVzXG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgdGFyZ2V0LmNsYXNzTGlzdC5yZW1vdmUoJ3JlcXVlc3QtaXRlbS1mbGlja2VyJyk7XG4gICAgICB9LCA0MDApOyAvLyBNYXRjaCB0aGUgYW5pbWF0aW9uIGR1cmF0aW9uXG4gICAgfVxuICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwicmVxdWVzdEl0ZW1zKCkgYXMgcmVxdWVzdEl0ZW1zXCI+XG4gICAgPGRpdiBpZD1cImNpZGUtbHl0LXJlcXVlc3Qtd3JhcHBlclwiIGNsYXNzPVwiY2lkZS1seXQtcmVxdWVzdCB0dy13LVtpbmhlcml0XVwiIFtjbGFzcy5jaWRlLWx5dC1yZXF1ZXN0LXdyYXBwZXItaGlkZV09XCIhcmVxdWVzdEl0ZW1zLmxlbmd0aFwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwicmVxdWVzdC1jb250ZW50IHR3LWZsZXggdHctaXRlbXMtY2VudGVyIHR3LW92ZXJmbG93LXgtYXV0b1wiPlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgaXRlbSBvZiByZXF1ZXN0SXRlbXM7IGxldCBpID0gaW5kZXhcIj5cbiAgICAgICAgICAgICAgICA8ZGl2ICNyZXF1ZXN0SXRlbUVsIGNsYXNzPVwicmVxdWVzdC1pdGVtXCIgKGtleWRvd24uZW50ZXIpPVwicmVxdWVzdFNlcnZpY2UuYWN0aXZhdGVUYWIoaXRlbS5pZCk7IGFwcGx5RmxpY2tlckVmZmVjdCgkZXZlbnQpXCJcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzLmFjdGl2ZV09XCJpdGVtLmFjdGl2ZVwiIHRhYmluZGV4PVwiMFwiIChjbGljayk9XCJyZXF1ZXN0U2VydmljZS5hY3RpdmF0ZVRhYihpdGVtLmlkKTsgYXBwbHlGbGlja2VyRWZmZWN0KCRldmVudClcIlxuICAgICAgICAgICAgICAgICAgICBbYXR0ci5kYXRhLXRvb2x0aXBdPVwiaXRlbS50aXRsZVwiPlxuICAgICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cInJlcXVlc3QtdGl0bGVcIj57eyBpdGVtLnRpdGxlIH19PC9zcGFuPlxuICAgICAgICAgICAgICAgICAgICA8YnV0dG9uIGNsYXNzPVwicmVxdWVzdC1hY3Rpb24gY2xvc2UtYWN0aW9uXCIgXG4gICAgICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwicmVxdWVzdFNlcnZpY2UuY2xvc2VUYWIoaXRlbS5pZCk7ICRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcIlxuICAgICAgICAgICAgICAgICAgICAgICAgKGtleWRvd24uZW50ZXIpPVwicmVxdWVzdFNlcnZpY2UuY2xvc2VUYWIoaXRlbS5pZCk7ICRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcIiBcbiAgICAgICAgICAgICAgICAgICAgICAgIHRhYmluZGV4PVwiMFwiXG4gICAgICAgICAgICAgICAgICAgICAgICBkYXRhLXRvb2x0aXA9XCJDbG9zZSB0aGlzIHRhYlwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGNpZGUtZWxlLWljb24gc2l6ZT1cIjN4c1wiPmNsb3NlPC9jaWRlLWVsZS1pY29uPlxuICAgICAgICAgICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8IS0tIE9ubHkgYWRkIGRpdmlkZXIgYmV0d2VlbiBpdGVtcyAtLT5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwicmVxdWVzdC1kaXZpZGVyXCIgKm5nSWY9XCJpIDwgcmVxdWVzdEl0ZW1zLmxlbmd0aCAtIDFcIj48L2Rpdj5cbiAgICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbjwvbmctY29udGFpbmVyPiJdfQ==
@@ -0,0 +1,235 @@
1
+ import { Injectable, inject, signal, computed } from '@angular/core';
2
+ import { Router, RouteReuseStrategy } from '@angular/router';
3
+ import { CustomRouteReuseStrategy } from '../../utils/custom-route-reuse-strategy';
4
+ import { TabStateService } from '../../services/tab-state.service';
5
+ import { CideLytSidedrawerService } from '../sidedrawer/sidedrawer.service';
6
+ import { CideLytSharedService } from '../shared/shared.service';
7
+ import * as i0 from "@angular/core";
8
+ export class CideLytRequestService {
9
+ constructor() {
10
+ this.requestVisible = false;
11
+ // Modern Angular v20+ pattern: Use Signals instead of BehaviorSubject
12
+ this.tabsSignal = signal([]);
13
+ this.activeTabIdSignal = signal(null);
14
+ // Computed signals for derived state and public readonly access
15
+ this.tabs = computed(() => this.tabsSignal());
16
+ this.activeTabId = computed(() => this.activeTabIdSignal());
17
+ this.activeTab = computed(() => this.tabsSignal().find(tab => tab.active));
18
+ // Use inject() for all dependencies
19
+ this.router = inject(Router);
20
+ this.routeReuseStrategy = inject(RouteReuseStrategy);
21
+ this.tabStateService = inject(TabStateService);
22
+ this.sidedrawerService = inject(CideLytSidedrawerService);
23
+ this.sharedService = inject(CideLytSharedService);
24
+ // Initialize router
25
+ this.router = inject(Router);
26
+ this.router.routeReuseStrategy = new CustomRouteReuseStrategy();
27
+ // Register tab management callback with shared service to avoid circular dependency
28
+ this.sharedService.registerTabManagement(this.handleRouteBasedTabManagement.bind(this));
29
+ // Register request visibility callback
30
+ this.sharedService.registerRequestVisibility(this.handleRequestVisibility.bind(this));
31
+ }
32
+ /**
33
+ * Handle request visibility changes from shared service
34
+ */
35
+ handleRequestVisibility(show) {
36
+ if (show) {
37
+ this.showRequest();
38
+ }
39
+ else {
40
+ this.hideRequest();
41
+ }
42
+ }
43
+ /**
44
+ * Handle sidebar sync when tab becomes active
45
+ */
46
+ handleSidebarSync(tabInfo) {
47
+ // The sidebar sync will be handled automatically by the shared service
48
+ // when page data is loaded, so we don't need additional logic here
49
+ console.log('🔗 REQUEST SERVICE: Tab activated, sidebar sync handled by shared service:', tabInfo.title);
50
+ }
51
+ /**
52
+ * Handle route-based tab management - called by shared service
53
+ * This method checks for existing tabs and creates/activates as needed
54
+ */
55
+ handleRouteBasedTabManagement(currentRoutePath, queryParams, layout, pageData, pageCode) {
56
+ console.log('handleRouteBasedTabManagement', currentRoutePath, queryParams, layout, pageData, pageCode);
57
+ const currentTabs = this.tabsSignal();
58
+ const tabAlreadyExists = currentTabs.find((t) => {
59
+ const tRoutePath = t.route.startsWith('/') ? t.route : '/' + t.route;
60
+ const tParamsMatch = JSON.stringify(t.params || {}) === JSON.stringify(queryParams || {});
61
+ return tRoutePath === currentRoutePath && tParamsMatch;
62
+ });
63
+ console.log('tabAlreadyExists', tabAlreadyExists);
64
+ if (!tabAlreadyExists) {
65
+ const title = pageData.data?.page?.sypg_title || pageCode.toString() || 'Untitled Tab';
66
+ console.log(`🆕 Adding new tab: ${title}`);
67
+ this.addTab(title, currentRoutePath, queryParams, layout);
68
+ }
69
+ else if (tabAlreadyExists && !tabAlreadyExists.active) {
70
+ console.log(`🔄 Activating existing tab: ${tabAlreadyExists.title}`);
71
+ this.activateTab(tabAlreadyExists.id);
72
+ }
73
+ else if (tabAlreadyExists && tabAlreadyExists.active) {
74
+ console.log(`🔄 Activating existing tab: ${tabAlreadyExists.title}`);
75
+ this.activateTab(tabAlreadyExists.id);
76
+ }
77
+ }
78
+ addTab(title, route, params, layout) {
79
+ console.log('addTab', title, route, params, layout);
80
+ const id = this.generateId();
81
+ const currentTabs = this.tabsSignal();
82
+ console.log('currentTabs', currentTabs, route);
83
+ // Check if a tab with the same route and params already exists
84
+ const existingTab = currentTabs.find((tab) => {
85
+ const paramsMatch = JSON.stringify(tab.params || {}) === JSON.stringify(params || {});
86
+ return tab.route === route && paramsMatch;
87
+ });
88
+ console.log('existingTab', existingTab);
89
+ if (existingTab) {
90
+ this.activateTab(existingTab.id);
91
+ return existingTab.id;
92
+ }
93
+ // Create new tab
94
+ const newTab = {
95
+ id,
96
+ title,
97
+ route,
98
+ params,
99
+ active: true,
100
+ layout,
101
+ sytm_page_id_sypg: '',
102
+ themeId: ''
103
+ };
104
+ // Deactivate all other tabs
105
+ currentTabs.forEach((tab) => tab.active = false);
106
+ console.log('currentTabs after deactivate', currentTabs, 'activateTab', id);
107
+ // Add new tab
108
+ this.tabsSignal.set([...currentTabs, newTab]);
109
+ this.activeTabIdSignal.set(id);
110
+ // Sync with TabStateService
111
+ this.tabStateService.addTab(title, id);
112
+ // Request visibility is now controlled by layout configuration in setPageData
113
+ // No need to automatically show request wrapper here
114
+ // Navigate to the new route
115
+ if (params) {
116
+ this.router.navigate([route], { queryParams: params });
117
+ }
118
+ else {
119
+ this.router.navigate([route]);
120
+ }
121
+ return id;
122
+ }
123
+ activateTab(tabId) {
124
+ console.log('🔍 REQUEST SERVICE: Activating tab:', tabId);
125
+ const tabs = this.tabsSignal();
126
+ const tabToActivate = tabs.find(tab => tab.id === tabId);
127
+ if (!tabToActivate) {
128
+ console.warn('⚠️ Tab not found:', tabId);
129
+ return;
130
+ }
131
+ // Update tabs: deactivate all, then activate the target
132
+ const updatedTabs = tabs.map(tab => ({
133
+ ...tab,
134
+ active: tab.id === tabId
135
+ }));
136
+ this.tabsSignal.set(updatedTabs);
137
+ this.activeTabIdSignal.set(tabId);
138
+ console.log('✅ REQUEST SERVICE: Tab activated:', tabToActivate.title);
139
+ // Navigate to the tab's route
140
+ this.router.navigate([tabToActivate.route], {
141
+ queryParams: tabToActivate.params || {},
142
+ replaceUrl: false
143
+ });
144
+ // Trigger sidebar sync for the activated tab by calling shared service
145
+ // The shared service will handle the sidebar sync when the route loads
146
+ console.log('🔗 REQUEST SERVICE: Sidebar sync will be handled by route change');
147
+ }
148
+ closeTab(id) {
149
+ const currentTabs = this.tabsSignal();
150
+ const tabIndex = currentTabs.findIndex((tab) => tab.id === id);
151
+ if (tabIndex === -1)
152
+ return;
153
+ const tabToClose = currentTabs[tabIndex];
154
+ const wasActive = tabToClose.active;
155
+ // Sync with TabStateService by removing the tab state
156
+ this.tabStateService.removeTab(id);
157
+ // Clear stored route from strategy
158
+ if (this.routeReuseStrategy instanceof CustomRouteReuseStrategy) {
159
+ let pathKey = tabToClose.route.startsWith('/') ? tabToClose.route.substring(1) : tabToClose.route;
160
+ if (tabToClose.params && Object.keys(tabToClose.params).length > 0) {
161
+ const queryParamsString = Object.keys(tabToClose.params)
162
+ .sort()
163
+ .map(key => `${key}=${tabToClose.params[key]}`)
164
+ .join('&');
165
+ pathKey += '?' + queryParamsString;
166
+ }
167
+ this.routeReuseStrategy.clearStoredRoute(pathKey);
168
+ }
169
+ // Remove the tab from this service's list
170
+ const newTabs = currentTabs.filter((tab) => tab.id !== id);
171
+ // If we're closing the active tab, activate the next available tab
172
+ if (wasActive && newTabs.length > 0) {
173
+ const newActiveIndex = Math.max(0, Math.min(tabIndex, newTabs.length - 1));
174
+ const newActiveTab = newTabs[newActiveIndex];
175
+ // Update sidedrawer for the new active tab
176
+ this.sidedrawerService.updateDrawerItems(newActiveTab.layout);
177
+ newTabs[newActiveIndex].active = true;
178
+ this.activeTabIdSignal.set(newActiveTab.id);
179
+ this.tabStateService.setActiveTab(newActiveTab.id);
180
+ // Navigate to the new active tab's route
181
+ if (newActiveTab.params) {
182
+ this.router.navigate([newActiveTab.route], { queryParams: newActiveTab.params });
183
+ }
184
+ else {
185
+ this.router.navigate([newActiveTab.route]);
186
+ }
187
+ }
188
+ else if (newTabs.length === 0) {
189
+ this.activeTabIdSignal.set(null);
190
+ this.tabStateService.setActiveTab(null);
191
+ // Clear sidedrawer as no tabs are open
192
+ this.sidedrawerService.updateDrawerItems(undefined);
193
+ }
194
+ this.tabsSignal.set(newTabs);
195
+ // Request wrapper visibility is now controlled by layout configuration
196
+ // The wrapper will be hidden/shown based on sytm_layout_request.status in setPageData
197
+ }
198
+ // Hide Request
199
+ hideRequest() {
200
+ console.log('🚫 REQUEST SERVICE - Hiding request wrapper');
201
+ this.requestVisible = false;
202
+ document.querySelector(`#cide-lyt-request-wrapper`)?.classList.add('cide-lyt-request-wrapper-hide');
203
+ document.querySelector(`body`)?.classList.remove('cide-lyt-request-exist');
204
+ }
205
+ // Show Request
206
+ showRequest() {
207
+ console.log('✅ REQUEST SERVICE - Showing request wrapper');
208
+ this.requestVisible = true;
209
+ document.querySelector(`#cide-lyt-request-wrapper`)?.classList.remove('cide-lyt-request-wrapper-hide');
210
+ document.querySelector(`body`)?.classList.add('cide-lyt-request-exist');
211
+ }
212
+ generateId() {
213
+ return 'tab-' + Math.random().toString(36).substr(2, 9);
214
+ }
215
+ updateTabScrollPosition(tabId, scrollTop, scrollLeft) {
216
+ const currentTabs = this.tabsSignal();
217
+ const tabIndex = currentTabs.findIndex((t) => t.id === tabId);
218
+ if (tabIndex !== -1) {
219
+ const tabToUpdate = currentTabs[tabIndex];
220
+ tabToUpdate.scrollTop = scrollTop;
221
+ tabToUpdate.scrollLeft = scrollLeft;
222
+ // Create a new array reference to trigger change detection
223
+ this.tabsSignal.set([...currentTabs]);
224
+ }
225
+ }
226
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
227
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestService, providedIn: 'root' }); }
228
+ }
229
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestService, decorators: [{
230
+ type: Injectable,
231
+ args: [{
232
+ providedIn: 'root'
233
+ }]
234
+ }], ctorParameters: () => [] });
235
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"request.service.js","sourceRoot":"","sources":["../../../../../../projects/cloud-ide-layout/src/lib/layout/request/request.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAA0B,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC7F,OAAO,EAAE,MAAM,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC7D,OAAO,EAAE,wBAAwB,EAAE,MAAM,yCAAyC,CAAC;AACnF,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAC5E,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;;AA6BhE,MAAM,OAAO,qBAAqB;IAoBhC;QAnBO,mBAAc,GAAY,KAAK,CAAC;QACvC,sEAAsE;QAC/D,eAAU,GAA8B,MAAM,CAAC,EAAE,CAAC,CAAC;QACnD,sBAAiB,GAAkC,MAAM,CAAC,IAAI,CAAC,CAAC;QAEvE,gEAAgE;QACzD,SAAI,GAAsB,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;QAC5D,gBAAW,GAA0B,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;QAC9E,cAAS,GAAgC,QAAQ,CAAC,GAAG,EAAE,CAC5D,IAAI,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAC1C,CAAC;QAEF,oCAAoC;QAC5B,WAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACxB,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAChD,oBAAe,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAC1C,sBAAiB,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QACrD,kBAAa,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAGnD,oBAAoB;QACpB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QAC7B,IAAI,CAAC,MAAM,CAAC,kBAAkB,GAAG,IAAI,wBAAwB,EAAE,CAAC;QAEhE,oFAAoF;QACpF,IAAI,CAAC,aAAa,CAAC,qBAAqB,CAAC,IAAI,CAAC,6BAA6B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAExF,uCAAuC;QACvC,IAAI,CAAC,aAAa,CAAC,yBAAyB,CAAC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACxF,CAAC;IAED;;OAEG;IACK,uBAAuB,CAAC,IAAa;QAC3C,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC;IACH,CAAC;IAED;;OAEG;IACK,iBAAiB,CAAC,OAAgB;QACxC,uEAAuE;QACvE,mEAAmE;QACnE,OAAO,CAAC,GAAG,CAAC,4EAA4E,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IAC3G,CAAC;IAED;;;OAGG;IACH,6BAA6B,CAC3B,gBAAwB,EACxB,WAAoC,EACpC,MAAmB,EACnB,QAA0B,EAC1B,QAAgB;QAEhB,OAAO,CAAC,GAAG,CAAC,+BAA+B,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;QACxG,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACtC,MAAM,gBAAgB,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,CAAU,EAAE,EAAE;YACvD,MAAM,UAAU,GAAG,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,KAAK,CAAC;YACrE,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YAC1F,OAAO,UAAU,KAAK,gBAAgB,IAAI,YAAY,CAAC;QACzD,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAAC;QAClD,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACtB,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,EAAE,IAAI,EAAE,UAAU,IAAI,QAAQ,CAAC,QAAQ,EAAE,IAAI,cAAc,CAAC;YACvF,OAAO,CAAC,GAAG,CAAC,sBAAsB,KAAK,EAAE,CAAC,CAAC;YAC3C,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC;QAC5D,CAAC;aAAM,IAAI,gBAAgB,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC;YACxD,OAAO,CAAC,GAAG,CAAC,+BAA+B,gBAAgB,CAAC,KAAK,EAAE,CAAC,CAAC;YACrE,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC;QACxC,CAAC;aAAK,IAAI,gBAAgB,IAAI,gBAAgB,CAAC,MAAM,EAAE,CAAC;YACtD,OAAO,CAAC,GAAG,CAAC,+BAA+B,gBAAgB,CAAC,KAAK,EAAE,CAAC,CAAC;YACrE,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAED,MAAM,CAAC,KAAa,EAAE,KAAa,EAAE,MAAgC,EAAE,MAAoB;QACzF,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;QACpD,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAC7B,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACtC,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;QAC/C,+DAA+D;QAC/D,MAAM,WAAW,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,GAAY,EAAE,EAAE;YACpD,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;YACtF,OAAO,GAAG,CAAC,KAAK,KAAK,KAAK,IAAI,WAAW,CAAC;QAC5C,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;QACxC,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YACjC,OAAO,WAAW,CAAC,EAAE,CAAC;QACxB,CAAC;QAED,iBAAiB;QACjB,MAAM,MAAM,GAAY;YACtB,EAAE;YACF,KAAK;YACL,KAAK;YACL,MAAM;YACN,MAAM,EAAE,IAAI;YACZ,MAAM;YACN,iBAAiB,EAAE,EAAE;YACrB,OAAO,EAAE,EAAE;SACZ,CAAC;QAEF,4BAA4B;QAC5B,WAAW,CAAC,OAAO,CAAC,CAAC,GAAY,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;QAC1D,OAAO,CAAC,GAAG,CAAC,8BAA8B,EAAE,WAAW,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;QAC5E,cAAc;QACd,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,GAAG,WAAW,EAAE,MAAM,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAE/B,4BAA4B;QAC5B,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEvC,8EAA8E;QAC9E,qDAAqD;QAErD,4BAA4B;QAC5B,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC,CAAC;QACzD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QAChC,CAAC;QAED,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,OAAO,CAAC,GAAG,CAAC,qCAAqC,EAAE,KAAK,CAAC,CAAC;QAC1D,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAC/B,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;QAEzD,IAAI,CAAC,aAAa,EAAE,CAAC;YACnB,OAAO,CAAC,IAAI,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC;YACzC,OAAO;QACT,CAAC;QAED,wDAAwD;QACxD,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACnC,GAAG,GAAG;YACN,MAAM,EAAE,GAAG,CAAC,EAAE,KAAK,KAAK;SACzB,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QACjC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAElC,OAAO,CAAC,GAAG,CAAC,mCAAmC,EAAE,aAAa,CAAC,KAAK,CAAC,CAAC;QAEtE,8BAA8B;QAC9B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE;YAC1C,WAAW,EAAE,aAAa,CAAC,MAAM,IAAI,EAAE;YACvC,UAAU,EAAE,KAAK;SAClB,CAAC,CAAC;QAEH,uEAAuE;QACvE,uEAAuE;QACvE,OAAO,CAAC,GAAG,CAAC,kEAAkE,CAAC,CAAC;IAClF,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACtC,MAAM,QAAQ,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC,GAAY,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QAExE,IAAI,QAAQ,KAAK,CAAC,CAAC;YAAE,OAAO;QAE5B,MAAM,UAAU,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;QACzC,MAAM,SAAS,GAAG,UAAU,CAAC,MAAM,CAAC;QAEpC,sDAAsD;QACtD,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QAEnC,mCAAmC;QACnC,IAAI,IAAI,CAAC,kBAAkB,YAAY,wBAAwB,EAAE,CAAC;YAChE,IAAI,OAAO,GAAG,UAAU,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC;YAElG,IAAI,UAAU,CAAC,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACnE,MAAM,iBAAiB,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;qBACrD,IAAI,EAAE;qBACN,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,IAAI,UAAU,CAAC,MAAO,CAAC,GAAG,CAAC,EAAE,CAAC;qBAC/C,IAAI,CAAC,GAAG,CAAC,CAAC;gBACb,OAAO,IAAI,GAAG,GAAG,iBAAiB,CAAC;YACrC,CAAC;YAEA,IAAI,CAAC,kBAA+C,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAClF,CAAC;QAED,0CAA0C;QAC1C,MAAM,OAAO,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,GAAY,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QAEpE,mEAAmE;QACnE,IAAI,SAAS,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpC,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;YAC3E,MAAM,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;YAE7C,2CAA2C;YAC3C,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;YAE9D,OAAO,CAAC,cAAc,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;YACtC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;YAC5C,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;YAEnD,yCAAyC;YACzC,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;gBACxB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,EAAE,WAAW,EAAE,YAAY,CAAC,MAAM,EAAE,CAAC,CAAC;YACnF,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;YAC7C,CAAC;QACH,CAAC;aAAM,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACjC,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YACxC,uCAAuC;YACvC,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;QACtD,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC7B,uEAAuE;QACvE,sFAAsF;IACxF,CAAC;IAED,eAAe;IACf,WAAW;QACT,OAAO,CAAC,GAAG,CAAC,6CAA6C,CAAC,CAAC;QAC3D,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,QAAQ,CAAC,aAAa,CAAC,2BAA2B,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,+BAA+B,CAAC,CAAC;QACpG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,SAAS,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAC;IAC7E,CAAC;IAED,eAAe;IACf,WAAW;QACT,OAAO,CAAC,GAAG,CAAC,6CAA6C,CAAC,CAAC;QAC3D,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,QAAQ,CAAC,aAAa,CAAC,2BAA2B,CAAC,EAAE,SAAS,CAAC,MAAM,CAAC,+BAA+B,CAAC,CAAC;QACvG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;IAC1E,CAAC;IAEO,UAAU;QAChB,OAAO,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED,uBAAuB,CAAC,KAAa,EAAE,SAAiB,EAAE,UAAkB;QAC1E,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACtC,MAAM,QAAQ,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC,CAAU,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,CAAC;QACvE,IAAI,QAAQ,KAAK,CAAC,CAAC,EAAE,CAAC;YACpB,MAAM,WAAW,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;YAC1C,WAAW,CAAC,SAAS,GAAG,SAAS,CAAC;YAClC,WAAW,CAAC,UAAU,GAAG,UAAU,CAAC;YACpC,2DAA2D;YAC3D,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;8GAhQU,qBAAqB;kHAArB,qBAAqB,cAFpB,MAAM;;2FAEP,qBAAqB;kBAHjC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable, inject, signal, WritableSignal, Signal, computed } from '@angular/core';\nimport { Router, RouteReuseStrategy } from '@angular/router';\nimport { CustomRouteReuseStrategy } from '../../utils/custom-route-reuse-strategy';\nimport { TabStateService } from '../../services/tab-state.service';\nimport { CideLytSidedrawerService } from '../sidedrawer/sidedrawer.service';\nimport { CideLytSharedService } from '../shared/shared.service';\nimport { ISytmLayout } from 'cloud-ide-lms-model';\n\nexport interface TabInfo {\n  id: string;\n  title: string;\n  route: string;\n  params?: Record<string, unknown>;\n  active: boolean;\n  sytm_page_id_sypg: string;\n  themeId: string;\n  loadedComponent?: unknown;\n  scrollTop?: number;\n  scrollLeft?: number;\n  layout?: ISytmLayout;\n}\n\n// Interface for page data passed from shared service\ninterface PageDataResponse {\n  data?: {\n    page?: {\n      sypg_title?: string;\n    };\n  };\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class CideLytRequestService {\n  public requestVisible: boolean = false;\n  // Modern Angular v20+ pattern: Use Signals instead of BehaviorSubject\n  public tabsSignal: WritableSignal<TabInfo[]> = signal([]);\n  public activeTabIdSignal: WritableSignal<string | null> = signal(null);\n  \n  // Computed signals for derived state and public readonly access\n  public tabs: Signal<TabInfo[]> = computed(() => this.tabsSignal());\n  public activeTabId: Signal<string | null> = computed(() => this.activeTabIdSignal());\n  public activeTab: Signal<TabInfo | undefined> = computed(() => \n    this.tabsSignal().find(tab => tab.active)\n  );\n\n  // Use inject() for all dependencies\n  private router = inject(Router);\n  private routeReuseStrategy = inject(RouteReuseStrategy);\n  private tabStateService = inject(TabStateService);\n  private sidedrawerService = inject(CideLytSidedrawerService);\n  private sharedService = inject(CideLytSharedService);\n\n  constructor() {\n    // Initialize router\n    this.router = inject(Router);\n    this.router.routeReuseStrategy = new CustomRouteReuseStrategy();\n    \n    // Register tab management callback with shared service to avoid circular dependency\n    this.sharedService.registerTabManagement(this.handleRouteBasedTabManagement.bind(this));\n    \n    // Register request visibility callback\n    this.sharedService.registerRequestVisibility(this.handleRequestVisibility.bind(this));\n  }\n\n  /**\n   * Handle request visibility changes from shared service\n   */\n  private handleRequestVisibility(show: boolean): void {\n    if (show) {\n      this.showRequest();\n    } else {\n      this.hideRequest();\n    }\n  }\n\n  /**\n   * Handle sidebar sync when tab becomes active\n   */\n  private handleSidebarSync(tabInfo: TabInfo): void {\n    // The sidebar sync will be handled automatically by the shared service\n    // when page data is loaded, so we don't need additional logic here\n    console.log('🔗 REQUEST SERVICE: Tab activated, sidebar sync handled by shared service:', tabInfo.title);\n  }\n\n  /**\n   * Handle route-based tab management - called by shared service\n   * This method checks for existing tabs and creates/activates as needed\n   */\n  handleRouteBasedTabManagement(\n    currentRoutePath: string,\n    queryParams: Record<string, unknown>,\n    layout: ISytmLayout,\n    pageData: PageDataResponse,\n    pageCode: string\n  ) {\n    console.log('handleRouteBasedTabManagement', currentRoutePath, queryParams, layout, pageData, pageCode);\n    const currentTabs = this.tabsSignal();\n    const tabAlreadyExists = currentTabs.find((t: TabInfo) => {\n      const tRoutePath = t.route.startsWith('/') ? t.route : '/' + t.route;\n      const tParamsMatch = JSON.stringify(t.params || {}) === JSON.stringify(queryParams || {});\n      return tRoutePath === currentRoutePath && tParamsMatch;\n    });\n    console.log('tabAlreadyExists', tabAlreadyExists);\n    if (!tabAlreadyExists) {\n      const title = pageData.data?.page?.sypg_title || pageCode.toString() || 'Untitled Tab';\n      console.log(`🆕 Adding new tab: ${title}`);\n      this.addTab(title, currentRoutePath, queryParams, layout);\n    } else if (tabAlreadyExists && !tabAlreadyExists.active) {\n      console.log(`🔄 Activating existing tab: ${tabAlreadyExists.title}`);\n      this.activateTab(tabAlreadyExists.id);\n    }else if (tabAlreadyExists && tabAlreadyExists.active) {\n      console.log(`🔄 Activating existing tab: ${tabAlreadyExists.title}`);\n      this.activateTab(tabAlreadyExists.id);\n    }\n  }\n\n  addTab(title: string, route: string, params?: Record<string, unknown>, layout?: ISytmLayout): string {\n    console.log('addTab', title, route, params, layout);\n    const id = this.generateId();\n    const currentTabs = this.tabsSignal();\n    console.log('currentTabs', currentTabs, route);\n    // Check if a tab with the same route and params already exists\n    const existingTab = currentTabs.find((tab: TabInfo) => {\n      const paramsMatch = JSON.stringify(tab.params || {}) === JSON.stringify(params || {});\n      return tab.route === route && paramsMatch;\n    });\n    console.log('existingTab', existingTab);\n    if (existingTab) {\n      this.activateTab(existingTab.id);\n      return existingTab.id;\n    }\n    \n    // Create new tab\n    const newTab: TabInfo = {\n      id,\n      title,\n      route,\n      params,\n      active: true,\n      layout,\n      sytm_page_id_sypg: '',\n      themeId: ''\n    };\n\n    // Deactivate all other tabs\n    currentTabs.forEach((tab: TabInfo) => tab.active = false);\n    console.log('currentTabs after deactivate', currentTabs, 'activateTab', id);\n    // Add new tab\n    this.tabsSignal.set([...currentTabs, newTab]);\n    this.activeTabIdSignal.set(id);\n\n    // Sync with TabStateService\n    this.tabStateService.addTab(title, id);\n    \n    // Request visibility is now controlled by layout configuration in setPageData\n    // No need to automatically show request wrapper here\n    \n    // Navigate to the new route\n    if (params) {\n      this.router.navigate([route], { queryParams: params });\n    } else {\n      this.router.navigate([route]);\n    }\n\n    return id;\n  }\n\n  activateTab(tabId: string): void {\n    console.log('🔍 REQUEST SERVICE: Activating tab:', tabId);\n    const tabs = this.tabsSignal();\n    const tabToActivate = tabs.find(tab => tab.id === tabId);\n    \n    if (!tabToActivate) {\n      console.warn('⚠️ Tab not found:', tabId);\n      return;\n    }\n\n    // Update tabs: deactivate all, then activate the target\n    const updatedTabs = tabs.map(tab => ({\n      ...tab,\n      active: tab.id === tabId\n    }));\n\n    this.tabsSignal.set(updatedTabs);\n    this.activeTabIdSignal.set(tabId);\n    \n    console.log('✅ REQUEST SERVICE: Tab activated:', tabToActivate.title);\n\n    // Navigate to the tab's route\n    this.router.navigate([tabToActivate.route], { \n      queryParams: tabToActivate.params || {},\n      replaceUrl: false \n    });\n    \n    // Trigger sidebar sync for the activated tab by calling shared service\n    // The shared service will handle the sidebar sync when the route loads\n    console.log('🔗 REQUEST SERVICE: Sidebar sync will be handled by route change');\n  }\n\n  closeTab(id: string): void {\n    const currentTabs = this.tabsSignal();\n    const tabIndex = currentTabs.findIndex((tab: TabInfo) => tab.id === id);\n\n    if (tabIndex === -1) return;\n\n    const tabToClose = currentTabs[tabIndex];\n    const wasActive = tabToClose.active;\n\n    // Sync with TabStateService by removing the tab state\n    this.tabStateService.removeTab(id);\n\n    // Clear stored route from strategy\n    if (this.routeReuseStrategy instanceof CustomRouteReuseStrategy) {\n      let pathKey = tabToClose.route.startsWith('/') ? tabToClose.route.substring(1) : tabToClose.route;\n\n      if (tabToClose.params && Object.keys(tabToClose.params).length > 0) {\n        const queryParamsString = Object.keys(tabToClose.params)\n          .sort()\n          .map(key => `${key}=${tabToClose.params![key]}`)\n          .join('&');\n        pathKey += '?' + queryParamsString;\n      }\n\n      (this.routeReuseStrategy as CustomRouteReuseStrategy).clearStoredRoute(pathKey);\n    }\n\n    // Remove the tab from this service's list\n    const newTabs = currentTabs.filter((tab: TabInfo) => tab.id !== id);\n\n    // If we're closing the active tab, activate the next available tab\n    if (wasActive && newTabs.length > 0) {\n      const newActiveIndex = Math.max(0, Math.min(tabIndex, newTabs.length - 1));\n      const newActiveTab = newTabs[newActiveIndex];\n\n      // Update sidedrawer for the new active tab\n      this.sidedrawerService.updateDrawerItems(newActiveTab.layout);\n\n      newTabs[newActiveIndex].active = true;\n      this.activeTabIdSignal.set(newActiveTab.id);\n      this.tabStateService.setActiveTab(newActiveTab.id);\n\n      // Navigate to the new active tab's route\n      if (newActiveTab.params) {\n        this.router.navigate([newActiveTab.route], { queryParams: newActiveTab.params });\n      } else {\n        this.router.navigate([newActiveTab.route]);\n      }\n    } else if (newTabs.length === 0) {\n      this.activeTabIdSignal.set(null);\n      this.tabStateService.setActiveTab(null);\n      // Clear sidedrawer as no tabs are open\n      this.sidedrawerService.updateDrawerItems(undefined);\n    }\n    this.tabsSignal.set(newTabs);\n    // Request wrapper visibility is now controlled by layout configuration\n    // The wrapper will be hidden/shown based on sytm_layout_request.status in setPageData\n  }\n\n  // Hide Request\n  hideRequest() {\n    console.log('🚫 REQUEST SERVICE - Hiding request wrapper');\n    this.requestVisible = false;\n    document.querySelector(`#cide-lyt-request-wrapper`)?.classList.add('cide-lyt-request-wrapper-hide');\n    document.querySelector(`body`)?.classList.remove('cide-lyt-request-exist');\n  }\n\n  // Show Request\n  showRequest() {\n    console.log('✅ REQUEST SERVICE - Showing request wrapper');\n    this.requestVisible = true;\n    document.querySelector(`#cide-lyt-request-wrapper`)?.classList.remove('cide-lyt-request-wrapper-hide');\n    document.querySelector(`body`)?.classList.add('cide-lyt-request-exist');\n  }\n\n  private generateId(): string {\n    return 'tab-' + Math.random().toString(36).substr(2, 9);\n  }\n\n  updateTabScrollPosition(tabId: string, scrollTop: number, scrollLeft: number): void {\n    const currentTabs = this.tabsSignal();\n    const tabIndex = currentTabs.findIndex((t: TabInfo) => t.id === tabId);\n    if (tabIndex !== -1) {\n      const tabToUpdate = currentTabs[tabIndex];\n      tabToUpdate.scrollTop = scrollTop;\n      tabToUpdate.scrollLeft = scrollLeft;\n      // Create a new array reference to trigger change detection\n      this.tabsSignal.set([...currentTabs]);\n    }\n  }\n}\n"]}
@@ -0,0 +1,84 @@
1
+ import { Component, ViewChild, effect } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { NavigationEnd, RouterModule } from '@angular/router';
4
+ import { filter } from 'rxjs/operators';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../request.service";
7
+ import * as i2 from "@angular/router";
8
+ export class TabContentComponent {
9
+ constructor(requestService, router, // Inject Router to listen for NavigationEnd
10
+ cdr) {
11
+ this.requestService = requestService;
12
+ this.router = router;
13
+ this.cdr = cdr;
14
+ this.currentActiveTabId = null;
15
+ this.isRestoringScroll = false; // Flag to prevent saving scroll during restoration attempts
16
+ // Modern Angular signal pattern: Use effect to react to active tab changes
17
+ effect(() => {
18
+ const activeTab = this.requestService.activeTab();
19
+ if (activeTab && activeTab.id !== this.currentActiveTabId) {
20
+ this.currentActiveTabId = activeTab.id;
21
+ // Delay scroll restoration to ensure DOM is ready
22
+ const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));
23
+ delay(100).then(() => this.restoreScrollPosition(activeTab));
24
+ }
25
+ });
26
+ // Listen to route changes for scroll restoration
27
+ this.router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe({
28
+ next: () => {
29
+ // Use signal to get active tab after navigation
30
+ const activeTab = this.requestService.activeTab();
31
+ if (activeTab && activeTab.id !== this.currentActiveTabId) {
32
+ this.currentActiveTabId = activeTab.id;
33
+ const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));
34
+ delay(150).then(() => this.restoreScrollPosition(activeTab));
35
+ }
36
+ }
37
+ });
38
+ }
39
+ ngAfterViewInit() {
40
+ // Initial scroll restoration for the active tab
41
+ const activeTab = this.requestService.activeTab();
42
+ if (activeTab) {
43
+ this.currentActiveTabId = activeTab.id;
44
+ const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));
45
+ delay(50).then(() => this.restoreScrollPosition(activeTab));
46
+ }
47
+ }
48
+ onScroll() {
49
+ if (this.isRestoringScroll || !this.scrollContainerRef || !this.currentActiveTabId) {
50
+ return;
51
+ }
52
+ const { scrollTop, scrollLeft } = this.scrollContainerRef.nativeElement;
53
+ this.requestService.updateTabScrollPosition(this.currentActiveTabId, scrollTop, scrollLeft);
54
+ }
55
+ restoreScrollPosition(tab) {
56
+ if (tab && this.scrollContainerRef?.nativeElement) {
57
+ this.isRestoringScroll = true;
58
+ const container = this.scrollContainerRef.nativeElement;
59
+ container.scrollTop = tab.scrollTop ?? 0;
60
+ container.scrollLeft = tab.scrollLeft ?? 0;
61
+ // Modern ES2022+ pattern: Use Promise-based delay
62
+ const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));
63
+ delay(150).then(() => { this.isRestoringScroll = false; }); // Allow scroll event to settle
64
+ }
65
+ }
66
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: TabContentComponent, deps: [{ token: i1.CideLytRequestService }, { token: i2.Router }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
67
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: TabContentComponent, isStandalone: true, selector: "cide-lyt-tab-content", viewQueries: [{ propertyName: "scrollContainerRef", first: true, predicate: ["scrollContainer"], descendants: true }], ngImport: i0, template: `
68
+ <div class="tab-content-container" #scrollContainer (scroll)="onScroll()">
69
+ <router-outlet></router-outlet>
70
+ </div>
71
+ `, isInline: true, styles: [":host{height:100%;display:flex;flex-direction:column}.tab-content-container{height:100%;width:100%;position:relative;overflow:auto;display:flex;flex-direction:column;flex:1}::ng-deep router-outlet+*{height:100%;flex:1;display:flex;flex-direction:column}::ng-deep cide-lyt-home-wrapper,::ng-deep cide-adm-home-wrapper,::ng-deep cide-adm-entity,::ng-deep cide-adm-entity-list{height:100%!important;flex:1!important;display:flex!important;flex-direction:column!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i2.RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }] }); }
72
+ }
73
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: TabContentComponent, decorators: [{
74
+ type: Component,
75
+ args: [{ selector: 'cide-lyt-tab-content', standalone: true, imports: [CommonModule, RouterModule], template: `
76
+ <div class="tab-content-container" #scrollContainer (scroll)="onScroll()">
77
+ <router-outlet></router-outlet>
78
+ </div>
79
+ `, styles: [":host{height:100%;display:flex;flex-direction:column}.tab-content-container{height:100%;width:100%;position:relative;overflow:auto;display:flex;flex-direction:column;flex:1}::ng-deep router-outlet+*{height:100%;flex:1;display:flex;flex-direction:column}::ng-deep cide-lyt-home-wrapper,::ng-deep cide-adm-home-wrapper,::ng-deep cide-adm-entity,::ng-deep cide-adm-entity-list{height:100%!important;flex:1!important;display:flex!important;flex-direction:column!important}\n"] }]
80
+ }], ctorParameters: () => [{ type: i1.CideLytRequestService }, { type: i2.Router }, { type: i0.ChangeDetectorRef }], propDecorators: { scrollContainerRef: [{
81
+ type: ViewChild,
82
+ args: ['scrollContainer']
83
+ }] } });
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-content.component.js","sourceRoot":"","sources":["../../../../../../../projects/cloud-ide-layout/src/lib/layout/request/tab-content/tab-content.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,SAAS,EAAoC,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3G,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAU,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAEtE,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;;;;AAgDxC,MAAM,OAAO,mBAAmB;IAM9B,YACU,cAAqC,EACrC,MAAc,EAAE,4CAA4C;IAC5D,GAAsB;QAFtB,mBAAc,GAAd,cAAc,CAAuB;QACrC,WAAM,GAAN,MAAM,CAAQ;QACd,QAAG,GAAH,GAAG,CAAmB;QANxB,uBAAkB,GAAkB,IAAI,CAAC;QACzC,sBAAiB,GAAG,KAAK,CAAC,CAAC,4DAA4D;QAO7F,2EAA2E;QAC3E,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC;YAClD,IAAI,SAAS,IAAI,SAAS,CAAC,EAAE,KAAK,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC1D,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC,EAAE,CAAC;gBACvC,kDAAkD;gBAClD,MAAM,KAAK,GAAG,CAAC,EAAU,EAAE,EAAE,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;gBAC9E,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC,CAAC;YAC/D,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,iDAAiD;QACjD,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CACrB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,YAAY,aAAa,CAAC,CAChD,CAAC,SAAS,CAAC;YACV,IAAI,EAAE,GAAG,EAAE;gBACT,gDAAgD;gBAChD,MAAM,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC;gBAClD,IAAI,SAAS,IAAI,SAAS,CAAC,EAAE,KAAK,IAAI,CAAC,kBAAkB,EAAE,CAAC;oBAC1D,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC,EAAE,CAAC;oBACvC,MAAM,KAAK,GAAG,CAAC,EAAU,EAAE,EAAE,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;oBAC9E,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC,CAAC;gBAC/D,CAAC;YACH,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,gDAAgD;QAChD,MAAM,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,CAAC;QAClD,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC,EAAE,CAAC;YACvC,MAAM,KAAK,GAAG,CAAC,EAAU,EAAE,EAAE,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;YAC9E,KAAK,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC,CAAC;QAC9D,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,kBAAkB,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACnF,OAAO;QACT,CAAC;QACD,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC;QACxE,IAAI,CAAC,cAAc,CAAC,uBAAuB,CAAC,IAAI,CAAC,kBAAkB,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;IAC9F,CAAC;IAEO,qBAAqB,CAAC,GAAwB;QACpD,IAAI,GAAG,IAAI,IAAI,CAAC,kBAAkB,EAAE,aAAa,EAAE,CAAC;YAClD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAC9B,MAAM,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC;YACxD,SAAS,CAAC,SAAS,GAAG,GAAG,CAAC,SAAS,IAAI,CAAC,CAAC;YACzC,SAAS,CAAC,UAAU,GAAG,GAAG,CAAC,UAAU,IAAI,CAAC,CAAC;YAC3C,kDAAkD;YAClD,MAAM,KAAK,GAAG,CAAC,EAAU,EAAE,EAAE,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;YAC9E,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,+BAA+B;QAC7F,CAAC;IACH,CAAC;8GAlEU,mBAAmB;kGAAnB,mBAAmB,uMA1CpB;;;;GAIT,+hBALS,YAAY,8BAAE,YAAY;;2FA2CzB,mBAAmB;kBA9C/B,SAAS;+BACE,sBAAsB,cACpB,IAAI,WACP,CAAC,YAAY,EAAE,YAAY,CAAC,YAC3B;;;;GAIT;+IAuC6B,kBAAkB;sBAA/C,SAAS;uBAAC,iBAAiB","sourcesContent":["import { Component, ElementRef, ViewChild, AfterViewInit, ChangeDetectorRef, effect } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NavigationEnd, Router, RouterModule } from '@angular/router';\nimport { CideLytRequestService, TabInfo } from '../request.service';\nimport { filter } from 'rxjs/operators';\n\n@Component({\n  selector: 'cide-lyt-tab-content',\n  standalone: true,\n  imports: [CommonModule, RouterModule],\n  template: `\n    <div class=\"tab-content-container\" #scrollContainer (scroll)=\"onScroll()\">\n      <router-outlet></router-outlet>\n    </div>\n  `,\n  styles: [`\n    :host {\n      height: 100%;\n      display: flex;\n      flex-direction: column;\n    }\n    \n    .tab-content-container {\n      height: 100%;\n      width: 100%;\n      position: relative;\n      overflow: auto;\n      display: flex;\n      flex-direction: column;\n      flex: 1;\n    }\n    \n    /* Ensure router outlet components take full height */\n    ::ng-deep router-outlet + * {\n      height: 100%;\n      flex: 1;\n      display: flex;\n      flex-direction: column;\n    }\n    \n    /* Specific height fixes for common component selectors */\n    ::ng-deep cide-lyt-home-wrapper,\n    ::ng-deep cide-adm-home-wrapper,\n    ::ng-deep cide-adm-entity,\n    ::ng-deep cide-adm-entity-list {\n      height: 100% !important;\n      flex: 1 !important;\n      display: flex !important;\n      flex-direction: column !important;\n    }\n  `]\n})\nexport class TabContentComponent implements AfterViewInit {\n  @ViewChild('scrollContainer') scrollContainerRef!: ElementRef<HTMLDivElement>;\n\n  private currentActiveTabId: string | null = null;\n  private isRestoringScroll = false; // Flag to prevent saving scroll during restoration attempts\n\n  constructor(\n    private requestService: CideLytRequestService,\n    private router: Router, // Inject Router to listen for NavigationEnd\n    private cdr: ChangeDetectorRef\n  ) {\n    // Modern Angular signal pattern: Use effect to react to active tab changes\n    effect(() => {\n      const activeTab = this.requestService.activeTab();\n      if (activeTab && activeTab.id !== this.currentActiveTabId) {\n        this.currentActiveTabId = activeTab.id;\n        // Delay scroll restoration to ensure DOM is ready\n        const delay = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\n        delay(100).then(() => this.restoreScrollPosition(activeTab));\n      }\n    });\n\n    // Listen to route changes for scroll restoration\n    this.router.events.pipe(\n      filter(event => event instanceof NavigationEnd)\n    ).subscribe({\n      next: () => {\n        // Use signal to get active tab after navigation\n        const activeTab = this.requestService.activeTab();\n        if (activeTab && activeTab.id !== this.currentActiveTabId) {\n          this.currentActiveTabId = activeTab.id;\n          const delay = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\n          delay(150).then(() => this.restoreScrollPosition(activeTab));\n        }\n      }\n    });\n  }\n\n  ngAfterViewInit(): void {\n    // Initial scroll restoration for the active tab\n    const activeTab = this.requestService.activeTab();\n    if (activeTab) {\n      this.currentActiveTabId = activeTab.id;\n      const delay = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\n      delay(50).then(() => this.restoreScrollPosition(activeTab));\n    }\n  }\n\n  onScroll(): void {\n    if (this.isRestoringScroll || !this.scrollContainerRef || !this.currentActiveTabId) {\n      return;\n    }\n    const { scrollTop, scrollLeft } = this.scrollContainerRef.nativeElement;\n    this.requestService.updateTabScrollPosition(this.currentActiveTabId, scrollTop, scrollLeft);\n  }\n\n  private restoreScrollPosition(tab: TabInfo | undefined): void {\n    if (tab && this.scrollContainerRef?.nativeElement) {\n      this.isRestoringScroll = true;\n      const container = this.scrollContainerRef.nativeElement;\n      container.scrollTop = tab.scrollTop ?? 0;\n      container.scrollLeft = tab.scrollLeft ?? 0;\n      // Modern ES2022+ pattern: Use Promise-based delay\n      const delay = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\n      delay(150).then(() => { this.isRestoringScroll = false; }); // Allow scroll event to settle\n    }\n  }\n\n\n}\n"]}
@@ -1,37 +1,49 @@
1
- import { Component } from '@angular/core';
1
+ import { Component, inject } from '@angular/core';
2
+ import { CideLytSharedService } from '../shared.service';
3
+ import { CideLytSidedrawerService } from '../../sidedrawer/sidedrawer.service';
4
+ import { AppStateHelperService } from '../../../services/app-state/app-state-helper.service';
2
5
  import * as i0 from "@angular/core";
3
- import * as i1 from "../shared.service";
4
6
  export class CideLytSharedWrapperComponent {
5
- constructor(sharedService) {
6
- this.sharedService = sharedService;
7
+ constructor() {
7
8
  this.shared_wrapper_setup_param = {};
8
9
  this.page_data = {};
10
+ this.sharedService = inject(CideLytSharedService);
11
+ this.sidedrawerService = inject(CideLytSidedrawerService);
12
+ this.appState = inject(AppStateHelperService);
9
13
  }
10
14
  ngOnInit() {
11
- // Load the page data
12
- this.loadPageData();
13
- }
14
- loadPageData() {
15
+ // Load and process page data using modern approach
15
16
  if (this.shared_wrapper_setup_param?.sypg_page_code) {
16
- const page_data_payload = { sypg_page_code: this.shared_wrapper_setup_param?.sypg_page_code };
17
- this.sharedService.loadPageData(page_data_payload)?.subscribe((page_data_response) => {
18
- if (page_data_response) {
17
+ const entityId = this.appState.getActiveEntityId();
18
+ const page_data_payload = {
19
+ sypg_page_code: this.shared_wrapper_setup_param?.sypg_page_code,
20
+ sytm_entity_id_syen: entityId || undefined
21
+ };
22
+ console.log('🔍 Page data payload:', page_data_payload);
23
+ this.sharedService.loadAndProcessPageData(page_data_payload, {
24
+ setTitle: true,
25
+ setSidebarContext: true,
26
+ updateLayout: true
27
+ }).subscribe({
28
+ next: (page_data_response) => {
29
+ console.log('✅ SHARED WRAPPER: Page data loaded and processed for:', page_data_payload.sypg_page_code);
19
30
  this.page_data = page_data_response?.data || {};
20
- this.sharedService.setPageData(page_data_response);
21
- // Set Page Tile
22
- this.setTitle(page_data_response?.data?.page?.sypg_title || '');
31
+ // Sidebar context is automatically set by loadAndProcessPageData when setSidebarContext: true
32
+ const pageId = page_data_response?.data?.page?._id || '';
33
+ const themeId = page_data_response?.data?.theme?._id || '';
34
+ this.sidedrawerService.setContext(pageId, themeId);
35
+ },
36
+ error: (err) => {
37
+ console.error('❌ SHARED WRAPPER: Error loading page data:', err);
23
38
  }
24
39
  });
25
40
  }
26
41
  }
27
- setTitle(title) {
28
- this.sharedService?.titleService.setTitle(title);
29
- }
30
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytSharedWrapperComponent, deps: [{ token: i1.CideLytSharedService }], target: i0.ɵɵFactoryTarget.Component }); }
42
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytSharedWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
31
43
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: CideLytSharedWrapperComponent, isStandalone: true, selector: "cide-lyt-shared-wrapper", ngImport: i0, template: "<p>shared-wrapper works!</p>\r\n", styles: [""] }); }
32
44
  }
33
45
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytSharedWrapperComponent, decorators: [{
34
46
  type: Component,
35
47
  args: [{ selector: 'cide-lyt-shared-wrapper', standalone: true, imports: [], template: "<p>shared-wrapper works!</p>\r\n" }]
36
- }], ctorParameters: () => [{ type: i1.CideLytSharedService }] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLXdyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xvdWQtaWRlLWxheW91dC9zcmMvbGliL2xheW91dC9zaGFyZWQvc2hhcmVkLXdyYXBwZXIvc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xvdWQtaWRlLWxheW91dC9zcmMvbGliL2xheW91dC9zaGFyZWQvc2hhcmVkLXdyYXBwZXIvc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQzs7O0FBV2xELE1BQU0sT0FBTyw2QkFBNkI7SUFHeEMsWUFBb0IsYUFBbUM7UUFBbkMsa0JBQWEsR0FBYixhQUFhLENBQXNCO1FBRmhELCtCQUEwQixHQUE0QyxFQUFFLENBQUM7UUFDekUsY0FBUyxHQUE2QixFQUFFLENBQUM7SUFFaEQsQ0FBQztJQUVELFFBQVE7UUFDTixxQkFBcUI7UUFDckIsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxZQUFZO1FBQ1YsSUFBSSxJQUFJLENBQUMsMEJBQTBCLEVBQUUsY0FBYyxFQUFFLENBQUM7WUFDcEQsTUFBTSxpQkFBaUIsR0FBa0IsRUFBRSxjQUFjLEVBQUUsSUFBSSxDQUFDLDBCQUEwQixFQUFFLGNBQWMsRUFBRSxDQUFBO1lBQzVHLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLGlCQUFpQixDQUFDLEVBQUUsU0FBUyxDQUFDLENBQUMsa0JBQWtELEVBQUUsRUFBRTtnQkFDbkgsSUFBSSxrQkFBa0IsRUFBRSxDQUFDO29CQUN2QixJQUFJLENBQUMsU0FBUyxHQUFHLGtCQUFrQixFQUFFLElBQUksSUFBSSxFQUFFLENBQUM7b0JBQ2hELElBQUksQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUFDLGtCQUFrQixDQUFDLENBQUM7b0JBQ25ELGdCQUFnQjtvQkFDaEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxrQkFBa0IsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLFVBQVUsSUFBSSxFQUFFLENBQUMsQ0FBQztnQkFDbEUsQ0FBQztZQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztJQUNILENBQUM7SUFFRCxRQUFRLENBQUMsS0FBYTtRQUNwQixJQUFJLENBQUMsYUFBYSxFQUFFLFlBQVksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbkQsQ0FBQzs4R0EzQlUsNkJBQTZCO2tHQUE3Qiw2QkFBNkIsbUZDWDFDLGtDQUNBOzsyRkRVYSw2QkFBNkI7a0JBUHpDLFNBQVM7K0JBQ0UseUJBQXlCLGNBQ3ZCLElBQUksV0FDUCxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2lkZUx5dFNoYXJlZFNlcnZpY2UgfSBmcm9tICcuLi9zaGFyZWQuc2VydmljZSc7XHJcbmltcG9ydCB7IGRlc2lnbkNvbmZpZ0NvbnRyb2xsZXJSZXNwb25zZSwgZGVzaWduQ29uZmlnUmVzcG9uc2VEYXRhLCBNRGVzaWduQ29uZmlnIH0gZnJvbSAnY2xvdWQtaWRlLWxtcy1tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2NpZGUtbHl0LXNoYXJlZC13cmFwcGVyJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9zaGFyZWQtd3JhcHBlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL3NoYXJlZC13cmFwcGVyLmNvbXBvbmVudC5jc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDaWRlTHl0U2hhcmVkV3JhcHBlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcHVibGljIHNoYXJlZF93cmFwcGVyX3NldHVwX3BhcmFtOiBQYXJ0aWFsPENpZGVMeXRTaGFyZWRXcmFwcGVyU2V0dXBQYXJhbT4gPSB7fTtcclxuICBwdWJsaWMgcGFnZV9kYXRhOiBkZXNpZ25Db25maWdSZXNwb25zZURhdGEgPSB7fTtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHNoYXJlZFNlcnZpY2U6IENpZGVMeXRTaGFyZWRTZXJ2aWNlKSB7XHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIC8vIExvYWQgdGhlIHBhZ2UgZGF0YVxyXG4gICAgdGhpcy5sb2FkUGFnZURhdGEoKTtcclxuICB9XHJcblxyXG4gIGxvYWRQYWdlRGF0YSgpIHtcclxuICAgIGlmICh0aGlzLnNoYXJlZF93cmFwcGVyX3NldHVwX3BhcmFtPy5zeXBnX3BhZ2VfY29kZSkge1xyXG4gICAgICBjb25zdCBwYWdlX2RhdGFfcGF5bG9hZDogTURlc2lnbkNvbmZpZyA9IHsgc3lwZ19wYWdlX2NvZGU6IHRoaXMuc2hhcmVkX3dyYXBwZXJfc2V0dXBfcGFyYW0/LnN5cGdfcGFnZV9jb2RlIH1cclxuICAgICAgdGhpcy5zaGFyZWRTZXJ2aWNlLmxvYWRQYWdlRGF0YShwYWdlX2RhdGFfcGF5bG9hZCk/LnN1YnNjcmliZSgocGFnZV9kYXRhX3Jlc3BvbnNlOiBkZXNpZ25Db25maWdDb250cm9sbGVyUmVzcG9uc2UpID0+IHtcclxuICAgICAgICBpZiAocGFnZV9kYXRhX3Jlc3BvbnNlKSB7XHJcbiAgICAgICAgICB0aGlzLnBhZ2VfZGF0YSA9IHBhZ2VfZGF0YV9yZXNwb25zZT8uZGF0YSB8fCB7fTtcclxuICAgICAgICAgIHRoaXMuc2hhcmVkU2VydmljZS5zZXRQYWdlRGF0YShwYWdlX2RhdGFfcmVzcG9uc2UpO1xyXG4gICAgICAgICAgLy8gU2V0IFBhZ2UgVGlsZVxyXG4gICAgICAgICAgdGhpcy5zZXRUaXRsZShwYWdlX2RhdGFfcmVzcG9uc2U/LmRhdGE/LnBhZ2U/LnN5cGdfdGl0bGUgfHwgJycpO1xyXG4gICAgICAgIH1cclxuICAgICAgfSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBzZXRUaXRsZSh0aXRsZTogc3RyaW5nKSB7XHJcbiAgICB0aGlzLnNoYXJlZFNlcnZpY2U/LnRpdGxlU2VydmljZS5zZXRUaXRsZSh0aXRsZSk7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENpZGVMeXRTaGFyZWRXcmFwcGVyU2V0dXBQYXJhbSB7XHJcbiAgc3lwZ19wYWdlX2NvZGU6IHN0cmluZ1xyXG59IiwiPHA+c2hhcmVkLXdyYXBwZXIgd29ya3MhPC9wPlxyXG4iXX0=
48
+ }] });
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLXdyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xvdWQtaWRlLWxheW91dC9zcmMvbGliL2xheW91dC9zaGFyZWQvc2hhcmVkLXdyYXBwZXIvc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xvdWQtaWRlLWxheW91dC9zcmMvbGliL2xheW91dC9zaGFyZWQvc2hhcmVkLXdyYXBwZXIvc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFekQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDL0UsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0RBQXNELENBQUM7O0FBUzdGLE1BQU0sT0FBTyw2QkFBNkI7SUFQMUM7UUFRUywrQkFBMEIsR0FBNEMsRUFBRSxDQUFDO1FBQ3pFLGNBQVMsR0FBNkIsRUFBRSxDQUFDO1FBQ3hDLGtCQUFhLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFDN0Msc0JBQWlCLEdBQUcsTUFBTSxDQUFDLHdCQUF3QixDQUFDLENBQUM7UUFDbkQsYUFBUSxHQUFHLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0tBa0NwRDtJQWhDQyxRQUFRO1FBQ04sbURBQW1EO1FBQ25ELElBQUksSUFBSSxDQUFDLDBCQUEwQixFQUFFLGNBQWMsRUFBRSxDQUFDO1lBQ3BELE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztZQUNuRCxNQUFNLGlCQUFpQixHQUFrQjtnQkFDdkMsY0FBYyxFQUFFLElBQUksQ0FBQywwQkFBMEIsRUFBRSxjQUFjO2dCQUMvRCxtQkFBbUIsRUFBRSxRQUFRLElBQUksU0FBUzthQUMzQyxDQUFDO1lBQ0YsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1lBRXhELElBQUksQ0FBQyxhQUFhLENBQUMsc0JBQXNCLENBQUMsaUJBQWlCLEVBQUU7Z0JBQzNELFFBQVEsRUFBRSxJQUFJO2dCQUNkLGlCQUFpQixFQUFFLElBQUk7Z0JBQ3ZCLFlBQVksRUFBRSxJQUFJO2FBQ25CLENBQUMsQ0FBQyxTQUFTLENBQUM7Z0JBQ1gsSUFBSSxFQUFFLENBQUMsa0JBQWtELEVBQUUsRUFBRTtvQkFDM0QsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1REFBdUQsRUFBRSxpQkFBaUIsQ0FBQyxjQUFjLENBQUMsQ0FBQztvQkFDdkcsSUFBSSxDQUFDLFNBQVMsR0FBRyxrQkFBa0IsRUFBRSxJQUFJLElBQUksRUFBRSxDQUFDO29CQUVoRCw4RkFBOEY7b0JBQzlGLE1BQU0sTUFBTSxHQUFHLGtCQUFrQixFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLEVBQUUsQ0FBQztvQkFDekQsTUFBTSxPQUFPLEdBQUcsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDO29CQUMzRCxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztnQkFDckQsQ0FBQztnQkFDRCxLQUFLLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRTtvQkFDYixPQUFPLENBQUMsS0FBSyxDQUFDLDRDQUE0QyxFQUFFLEdBQUcsQ0FBQyxDQUFDO2dCQUNuRSxDQUFDO2FBQ0YsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztJQUNILENBQUM7OEdBcENVLDZCQUE2QjtrR0FBN0IsNkJBQTZCLG1GQ2IxQyxrQ0FDQTs7MkZEWWEsNkJBQTZCO2tCQVB6QyxTQUFTOytCQUNFLHlCQUF5QixjQUN2QixJQUFJLFdBQ1AsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENpZGVMeXRTaGFyZWRTZXJ2aWNlIH0gZnJvbSAnLi4vc2hhcmVkLnNlcnZpY2UnO1xuaW1wb3J0IHsgZGVzaWduQ29uZmlnQ29udHJvbGxlclJlc3BvbnNlLCBkZXNpZ25Db25maWdSZXNwb25zZURhdGEsIE1EZXNpZ25Db25maWcgfSBmcm9tICdjbG91ZC1pZGUtbG1zLW1vZGVsJztcbmltcG9ydCB7IENpZGVMeXRTaWRlZHJhd2VyU2VydmljZSB9IGZyb20gJy4uLy4uL3NpZGVkcmF3ZXIvc2lkZWRyYXdlci5zZXJ2aWNlJztcbmltcG9ydCB7IEFwcFN0YXRlSGVscGVyU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2FwcC1zdGF0ZS9hcHAtc3RhdGUtaGVscGVyLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjaWRlLWx5dC1zaGFyZWQtd3JhcHBlcicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtdLFxuICB0ZW1wbGF0ZVVybDogJy4vc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50LmNzcydcbn0pXG5leHBvcnQgY2xhc3MgQ2lkZUx5dFNoYXJlZFdyYXBwZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBwdWJsaWMgc2hhcmVkX3dyYXBwZXJfc2V0dXBfcGFyYW06IFBhcnRpYWw8Q2lkZUx5dFNoYXJlZFdyYXBwZXJTZXR1cFBhcmFtPiA9IHt9O1xuICBwdWJsaWMgcGFnZV9kYXRhOiBkZXNpZ25Db25maWdSZXNwb25zZURhdGEgPSB7fTtcbiAgcHJpdmF0ZSBzaGFyZWRTZXJ2aWNlID0gaW5qZWN0KENpZGVMeXRTaGFyZWRTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBzaWRlZHJhd2VyU2VydmljZSA9IGluamVjdChDaWRlTHl0U2lkZWRyYXdlclNlcnZpY2UpO1xuICBwcm90ZWN0ZWQgYXBwU3RhdGUgPSBpbmplY3QoQXBwU3RhdGVIZWxwZXJTZXJ2aWNlKTtcblxuICBuZ09uSW5pdCgpIHtcbiAgICAvLyBMb2FkIGFuZCBwcm9jZXNzIHBhZ2UgZGF0YSB1c2luZyBtb2Rlcm4gYXBwcm9hY2hcbiAgICBpZiAodGhpcy5zaGFyZWRfd3JhcHBlcl9zZXR1cF9wYXJhbT8uc3lwZ19wYWdlX2NvZGUpIHtcbiAgICAgIGNvbnN0IGVudGl0eUlkID0gdGhpcy5hcHBTdGF0ZS5nZXRBY3RpdmVFbnRpdHlJZCgpO1xuICAgICAgY29uc3QgcGFnZV9kYXRhX3BheWxvYWQ6IE1EZXNpZ25Db25maWcgPSB7IFxuICAgICAgICBzeXBnX3BhZ2VfY29kZTogdGhpcy5zaGFyZWRfd3JhcHBlcl9zZXR1cF9wYXJhbT8uc3lwZ19wYWdlX2NvZGUsIFxuICAgICAgICBzeXRtX2VudGl0eV9pZF9zeWVuOiBlbnRpdHlJZCB8fCB1bmRlZmluZWQgXG4gICAgICB9O1xuICAgICAgY29uc29sZS5sb2coJ/CflI0gUGFnZSBkYXRhIHBheWxvYWQ6JywgcGFnZV9kYXRhX3BheWxvYWQpO1xuICAgICAgXG4gICAgICB0aGlzLnNoYXJlZFNlcnZpY2UubG9hZEFuZFByb2Nlc3NQYWdlRGF0YShwYWdlX2RhdGFfcGF5bG9hZCwge1xuICAgICAgICBzZXRUaXRsZTogdHJ1ZSxcbiAgICAgICAgc2V0U2lkZWJhckNvbnRleHQ6IHRydWUsXG4gICAgICAgIHVwZGF0ZUxheW91dDogdHJ1ZVxuICAgICAgfSkuc3Vic2NyaWJlKHtcbiAgICAgICAgbmV4dDogKHBhZ2VfZGF0YV9yZXNwb25zZTogZGVzaWduQ29uZmlnQ29udHJvbGxlclJlc3BvbnNlKSA9PiB7XG4gICAgICAgICAgY29uc29sZS5sb2coJ+KchSBTSEFSRUQgV1JBUFBFUjogUGFnZSBkYXRhIGxvYWRlZCBhbmQgcHJvY2Vzc2VkIGZvcjonLCBwYWdlX2RhdGFfcGF5bG9hZC5zeXBnX3BhZ2VfY29kZSk7XG4gICAgICAgICAgdGhpcy5wYWdlX2RhdGEgPSBwYWdlX2RhdGFfcmVzcG9uc2U/LmRhdGEgfHwge307XG4gICAgICAgICAgXG4gICAgICAgICAgLy8gU2lkZWJhciBjb250ZXh0IGlzIGF1dG9tYXRpY2FsbHkgc2V0IGJ5IGxvYWRBbmRQcm9jZXNzUGFnZURhdGEgd2hlbiBzZXRTaWRlYmFyQ29udGV4dDogdHJ1ZVxuICAgICAgICAgIGNvbnN0IHBhZ2VJZCA9IHBhZ2VfZGF0YV9yZXNwb25zZT8uZGF0YT8ucGFnZT8uX2lkIHx8ICcnO1xuICAgICAgICAgIGNvbnN0IHRoZW1lSWQgPSBwYWdlX2RhdGFfcmVzcG9uc2U/LmRhdGE/LnRoZW1lPy5faWQgfHwgJyc7XG4gICAgICAgICAgdGhpcy5zaWRlZHJhd2VyU2VydmljZS5zZXRDb250ZXh0KHBhZ2VJZCwgdGhlbWVJZCk7XG4gICAgICAgIH0sXG4gICAgICAgIGVycm9yOiAoZXJyKSA9PiB7XG4gICAgICAgICAgY29uc29sZS5lcnJvcign4p2MIFNIQVJFRCBXUkFQUEVSOiBFcnJvciBsb2FkaW5nIHBhZ2UgZGF0YTonLCBlcnIpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2lkZUx5dFNoYXJlZFdyYXBwZXJTZXR1cFBhcmFtIHtcbiAgc3lwZ19wYWdlX2NvZGU6IHN0cmluZ1xufSIsIjxwPnNoYXJlZC13cmFwcGVyIHdvcmtzITwvcD5cclxuIl19